0

我的 tex/csv 文件有 3 列first_name, 但我的数据库表有两列last_name和. 我希望有一个功能,即使表中不存在很多列,它仍然可以选择正确的列并插入到表中。有人建议我使用 php 。我正在尝试,我可以收集我的数据库表列名称,但我无法根据表头插入数据。 addressfirst_namelast_namecsvmysql_fetch_fieldmysql_fetch_field

     set_time_limit(0);

    include "connection.php"; //Connect to Database


    if (isset($_POST['submit'])) {

    // Gel table current column name

    $query = "select * from month";
    $result=mysql_query($query) or die (mysql_error());

    $i = 0;
    while ($i < mysql_num_fields($result)) {
        $meta = mysql_fetch_field($result, $i);

        $a=$meta->name;

        $i++;
    }

    //Upload File

    if (is_uploaded_file($_FILES['filename']['tmp_name'])) {
            echo "<h1>" . "File ". $_FILES['filename']['name'] ." uploaded successfully." . "</h1>";
            echo "<h2>Displaying contents:</h2>";
            readfile($_FILES['filename']['tmp_name']);
        }

        //Import uploaded file to Database
        $handle = fopen($_FILES['filename']['tmp_name'], "r");

            $header = fgetcsv($handle);


        while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
            $import="INSERT into month($header[0],$header[1]) values('$data[0]','$data[1]')";

            mysql_query($import) or die(mysql_error());
        }

        fclose($handle);

        echo "Import done";

    }
4

2 回答 2

0

您可以使用 MySQL 的LOAD DATA INFILE命令。如手册中所述:

您还可以通过将输入值分配给用户变量而不将变量分配给表列来丢弃输入值:

加载数据文件'file.txt'
  进入表 t1
  (column1,@dummy,column2,@dummy,column3);

因此,在您的情况下:

LOAD DATA INFILE '/path/to/file' INTO TABLE month
  FIELDS TERMINATED BY ',' ENCLOSED BY '"'
  IGNORE 1 LINES
  (first_name, last_name, @dummy);
于 2012-09-04T11:28:59.193 回答
0

我不确定我能得到你需要的东西,但我认为你应该像这样MySQL Load Data Infile加载它CSV

LOAD DATA LOCAL INFILE 'your_file.csv'
INTO TABLE your_table
FIELDS TERMINATED BY ';'
LINES TERMINATED BY '\r\n'
(field1, field2, field3)

这就是我的工作方式CSV,它做得很好。

检查此链接

于 2012-09-04T11:29:01.013 回答