22. oktober 2018 - 14:02 Der er 5 kommentarer

Hjælp til : Insert Into

HEJ,

Jeg prøver at lægge CSV data ind i en tabel på min Webserver,

Først åbner jeg forbindelsen - ingen problemer her:

Jeg prøvede først med den kommando hvor jeg kan hente en CSV fil direkte ind i tabellen (kan selvfølgelig ikke finde syntaksen nu !!!! )  det fungerede ikke.... (suk),

Så åbner jeg filen ($handle = fopen(filenav,'r') ..
Læser linien, exploder til $Vars og insetter derefter i min tabel. 

Jeg har af testhensyn lave linien echo ($Vars[0] ..... , $Vars[3]);
og den udskriver de korrekte værdier.

DET FUNGERER HELLER IKKE  (mere suk).

Hvad er det jeg gør galt ?

her er koden:

<?php

    $host = 'localhost'; 
    $user =  "uuuuuul";
    $pass =  "ppppp";
    $dbname = "dbdbdbdbdb";
   
  ?>

<html>
  <head>
      <title>Creating MySQLi Tables</title>
  </head>
 
<body>
    <?php 
        $conn = mysqli_connect($host, $user, $pass,$dbname); 
        if(!$conn)
        { 
            die('Could not connect: '.mysqli_connect_error()); 
        } 
   
        echo 'Connected successfully<br>'; 
       
        if (file_exists("testfil.csv"))
        {
                echo 'Filen testfil.csv eksisterer  <BR>';
                $sql = "TRUNCATE TABLE csvdata";
                if(mysqli_query($conn, $sql))
                { 
                    echo "Table csvdata is nulstillet <BR>"; 
                }       
           
                echo 'insert new data to csvtable <br>';
           
                $file = "testfil.csv";
                $handle = fopen ($file,'r');
                while(!feof($handle))
                {
                    $strng = fgets($handle);
                    $Vars = explode(',',$strng);
                    $sql = "INSERT INTO csvdata('title', 'dato', 'testp') VALUES ('$Vars[1]', '$Vars[2]','$Vars[3]')";
                    if (mysqli_query($conn, $sql))
                    {
                        echo "New record created successfully <BR>";
                    }
                    else
                    {
                        echo "Error: " . $sql . "" . mysqli_error($conn)."<br>";
                    }
                }
                fclose($handle); 
                echo 'nu skulle data være inde <br>';       
        }
        else
        {
            echo 'Filen testfil.csv eksisterer ikke  <BR>';
            echo  ' IKKE  clear table csvdata ';   
        }
        mysqli_close($conn); 
      ?> 
   
    <h1>HEJ </h1>
 
</body>
</html>

og her er testfil.csv

id,title,dato,testp
1,"aaa","1111","tp1"
2,"bbb","2222","tp2"
3,"ccc","3333","tp3"
4,"ddd","4444","tp4"
5,"eee","5555","tp5"
6,"fff","6666","tp6"
7,"ggg","7777","tp7"
Avatar billede Slater Ekspert
22. oktober 2018 - 14:10 #1
Kan du beskrive problemet lidt bedre end "det fungerer ikke"?

Hvor langt kommer det? Får du en fejlbesked? Bliver noget sat ind? Ser du din færdig-besked? Osv.
Avatar billede arne_v Ekspert
22. oktober 2018 - 14:19 #2
INSERT INTO csvdata('title', 'dato', 'testp')

ser ihvertfald forkert ud.

Det skal vaere enten ingen eller fremadhaeldende single quotes - ikke lodrette single quotes.
Avatar billede arne_v Ekspert
22. oktober 2018 - 14:21 #3
Jeg kan ikke huske PHP's regler for brug af $ i "" strenge godt nok til at vide om:

VALUES ('$Vars[1]', '$Vars[2]','$Vars[3]')";

er OK.

Men naar nu du bruger mysqli, saa brug da prepared statement!!
Avatar billede Slater Ekspert
22. oktober 2018 - 14:53 #4
#3: Der er ikke noget galt med den brug af dynamiske strenge - det er kun et problem med associative arrays, f.eks. "a $var['test'] b" ville give en fejl. Den skal i stedet skrives som  "a ${var['test']} b".

Men enig.
22. oktober 2018 - 15:00 #5
HEJ

Arne_V #2 og #3:

Det er nogen dage ( = mange) jeg har beskæftiget mig med PHP, men dine indlæg
fik mig til at tænke mig om:  (Tak for det  !! (hehe) - det er farligt- jeg får ideer).

Gik ind på w3Schools og søge på syntaksen på INSERT INTO...  og der er det som du så korrekt nævner INGEN  "  '  "  i første del af INSERT INTO - altså

$sql = "INSERT INTO csvdata(title, dato, testp)  ...

prøvede det på filen , og VOILA der var fejlen.

Så mange tak for hjælpen, men nogen gange er man (= jeg) så optaget af et problem, at  man (= igen jeg), ikke kan se skoven for bare træer....  Og så er det bare skønt, at få hjælp fra eksterne "skov-huggere" .. hehe .

Så nok en gang - Tak for hjælpen.

KR
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester