将CSV文件上传到MySql

时间:2016-11-29 02:44:58

标签: php mysql csv mysqli

我正在尝试创建一个简单的表单,使用MySQLi面向对象将CSV文件上传到MySql。与数据库的连接工作正常但由于某种原因我还没想到它没有将CSV文件中的数据插入到数据库中。

$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>

1 个答案:

答案 0 :(得分:-1)

  1. 请检查文件类型。必须是.csv。
  2. 请检查您的csv文件并删除您编写列名的行。