开发者社区 问答 正文

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

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

展开
收起
保持可爱mmm 2020-05-17 18:48:59 935 分享 版权
1 条回答
写回答
取消 提交回答
  • 您也可以通过将输入值分配给用户变量而不将变量分配给表列来丢弃它:

    LOAD DATA INFILE 'file.txt'
    INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);来源:stack overflow

    2020-05-17 18:53:09
    赞同 展开评论