我有一个包含11列的CSV文件和一个包含9列的MySQL表。
CSV文件如下所示:
col1, col2, col3, col4, col5, col6, col7, col8, col9, col10, col11
MySQL表如下所示:
col1, col2, col3, col4, col5, col6, col7, col8, col9
我需要将CSV文件的第1-8列直接映射到MySQL表的前8列。然后,我需要跳过CSV文件中的下两列,然后将CSV文件的第11列映射到MySQL表的第9列。
目前,我正在使用以下SQL命令:
LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'
但是上面的代码将CSV文件的前9列映射到MySQL表中的9列。
发布于 2014-11-13 14:04:52
忽略@dummy
的唯一方法是将字段的默认值设置为AUTO INCREMENT
。所以你可以跳过这个字段,像这样编写代码,
LOAD DATA INFILE 'file.txt'
INTO TABLE t1 (column2, column3, column4, column5);
//假定fieldname column1
默认设置为AUTO INCREMENT
。
发布于 2014-11-13 14:10:18
我认为代码中还有一个变化:
以下SQL命令:
LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'
-will可能会导致数据截断错误。
因此,最好使用LINES TERMINATED BY '\r\n'
而不是LINES TERMINATED BY '\n'
因此代码将是:
LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\r\n'
https://stackoverflow.com/questions/2139069
复制相似问题