How to skip columns in CSV file when importing into MySQL table using LOAD DATA INFILE?(使用 LOAD DATA INFILE 导入 MySQL 表时如何跳过 CSV 文件中的列?)
问题描述
我有一个有 11 列的 CSV 文件,我有一个有 9 列的 MySQL 表.
I've got a CSV file with 11 columns and I have a MySQL table with 9 columns.
CSV 文件如下所示:
The CSV file looks like:
col1, col2, col3, col4, col5, col6, col7, col8, col9, col10, col11
MySQL 表如下所示:
and the MySQL table looks like:
col1, col2, col3, col4, col5, col6, col7, col8, col9
我需要将 CSV 文件的第 1-8 列直接映射到 MySQL 表的前 8 列.然后我需要跳过 CSV 文件中接下来的两列,然后将 CSV 文件的第 11 列映射到 MySQL 表的第 9 列.
I need to map the columns 1-8 of CSV file directly to the first 8 columns of the MySQL table. I then need to skip the next two columns in the CSV file and then map column 11 of CSV file to column 9 of MySQL table.
目前我正在使用以下 SQL 命令:
At the moment I am using the following SQL command:
LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'
但是上面的代码将CSV文件的前9列映射到了MySQL表的9列.
But the above code maps the first 9 columns of CSV file to the 9 columns in the MySQL table.
推荐答案
来自 Mysql 文档:
您还可以通过以下方式丢弃输入值将其分配给用户变量和不将变量分配给表列:
You can also discard an input value by assigning it to a user variable and not assigning the variable to a table column:
LOAD DATA INFILE 'file.txt'
INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);
这篇关于使用 LOAD DATA INFILE 导入 MySQL 表时如何跳过 CSV 文件中的列?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用 LOAD DATA INFILE 导入 MySQL 表时如何跳过 CSV 文件中的列?


- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- SQL 临时表问题 2022-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 更改自动增量起始编号? 2021-01-01