繁体   English   中英

使用LOAD DATA INFILE导入MySQL表时如何跳过CSV文件中的列?

[英]How to skip columns in CSV file when importing into MySQL table using LOAD DATA INFILE?

我有一个包含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列。

来自Mysql文档:

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

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);

step1.deal with awk。

cat file.txt |awk '{print $1,$2,$5...}'>new_file.txt

step2.load into mysql。

load data local infile 'new_file' into table t1(...)

下面的方法很简单,但在较低版本的mysql中不允许。

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);

@ deemi

忽略@dummy的唯一方法是将字段的Default设置为AUTO INCREMENT 所以你可以跳过这个字段,只是像这样编码,

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column2, column3, column4, column5);

//假设默认情况下fieldname column1设置为AUTO INCREMENT

我认为代码还有一个变化:

以下SQL命令:

LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'

- 可能会导致数据截断错误。

所以最好使用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'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM