2016-11-29 4 views
-1

Я пытаюсь создать простую форму для загрузки CSV-файлов в MySql, используя MySQLi Object-oriented. Соединение с БД работает нормально, но по какой-то причине я еще не понял, что он не вставляет данные из файла CSV в БД.Загрузить CSV-файл в MySql

$servername = "localhost"; 
$username = "user_name"; 
$password = "password"; 
$dbname = "db_name"; 

// Create connection 
$conn = new mysqli($servername, $username, $password, $dbname); 

// Check connection 
if ($conn->connect_error) { 
    die("Connection failed: " . $conn->connect_error); 
} 

if(isset($_POST["submit"])) { 
    if($_FILES['file']['name']) { 
     $filename = explode(".", $_FILES['file']['name']); 
     if ($filename[1] == 'csv') { 

      $handle = fopen($_FILES['file']['tmp_name'], "r"); 
      while($data = fgetcsv($handle)) { 
       $user_id = mysqli_real_escape_string($conn, $data[1]); 
       $name = mysqli_real_escape_string($conn, $data[2]); 
       $last_mod = mysqli_real_escape_string($conn, $data[3]); 

       $sql="INSERT into user (user_id, name, last_mod) VALUES ('$user_id', '$name', '$last_mod')"; 
       if (!mysqli_query($con,$sql)) { 
       die('Error: ' . mysqli_error($con)); 
       } 
       echo "1 record added"; 
      } 

      $conn->close(); 
     } 
    } 

} 

<form action="index.php" method="POST" enctype="multipart/form-data" name="beer"> 
<div class="form-group"> 
<label for="file">Select your file:</label> 
<input name="file" type="file"> 
</div> 
<div class="checkbox"> 
<label><input type="checkbox">I agree!</label> 
</div> 
<button type="submit" class="btn btn-default">Upload</button> 
</form> 
+0

Возможно, мне что-то не хватает, но где вы устанавливаете '$ row'? – andrewsi

+0

@andrewsi ... извините, что это была старая версия, я изменил ее на «данные» – user3767773

+1

что случилось с 'LOAD DATA INFILE'? – e4c5

ответ

-1
  1. пожалуйста, проверьте тип файла. Это должно быть .csv.
  2. Проверьте файл csv и удалите строку с именем столбца.