MySQL多值插入最常用写法是INSERT INTO table (c1,c2) VALUES (v1,v2),(v3,v4);单语句建议≤1000行,冲突时可用INSERT IGNORE跳过或ON DUPLICATE KEY UPDATE更新,大数据量优先LOAD DATA INFILE。

MySQL INSERT INTO VALUES 多值插入最常用写法
直接在一条 INSERT INTO 语句中列出多组值,用逗号分隔,是 MySQL 原生支持、兼容性好、性能合理的批量插入方式。
常见错误是把多条 INSERT 拼成一个长语句但没加逗号,或误以为必须用 INSERT ... SELECT。
- 语法必须是:
INSERT INTO table (col1, col2) VALUES (v1,v2), (v3,v4), (v5,v6); - 每组括号内字段数和类型必须与列定义严格一致
- 单条语句建议不超过 1000 行(受
max_allowed_packet和性能影响) - 遇到主键/唯一键冲突时,默认会中断整个语句;如需跳过冲突行,改用
INSERT IGNORE或ON DUPLICATE KEY UPDATE
INSERT IGNORE 和 ON DUPLICATE KEY UPDATE 的区别场景
当批量插入可能含重复主键或唯一索引值时,这两个选项决定行为走向,不能混用。
-
INSERT IGNORE:遇到重复键就跳过该行,不报错,也不更新已有数据 -
ON DUPLICATE KEY UPDATE:遇到重复键则执行指定的更新操作,比如INSERT INTO t (id,name) VALUES (1,'a'),(2,'b') ON DUPLICATE KEY UPDATE name=VALUES(name); - 注意
VALUES(col)是特殊函数,返回本次 INSERT 中对应列的值,不是字面量VALUES - 若表有多个唯一索引,任一触发都会激活
ON DUPLICATE KEY UPDATE
用 LOAD DATA INFILE 替代 INSERT 的真实条件
当数据源是本地 CSV 或文本文件,且对导入速度敏感(比如 >10 万行),LOAD DATA INFILE 比拼接 SQL 快 5–10 倍,但它不是“语法替代”,而是另一套路径。
- 要求 MySQL 服务端能读取该文件路径(不是客户端机器),除非加
LOCAL关键字(需服务端开启local_infile=ON) - 字段分隔符、行结束符、转义字符必须显式声明,例如:
LOAD DATA INFILE '/tmp/data.csv' INTO TABLE t FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n'; - 不走 SQL 解析器,无法触发触发器,也不会被普通事务完全包裹(InnoDB 下仍可回滚,但机制不同)
- 字段顺序必须与文件列顺序一致,或用
(col1,col2)显式映射
Python / Java 等应用层批量插入的注意事项
应用代码里拼接多值 INSERT 很常见,但容易忽略连接层和数据库层的隐性限制。
- 预处理语句(如 Python 的
executemany())底层仍是多次单条或自动打包为多值VALUES,具体取决于驱动实现 - MySQL 连接默认启用
autocommit=False,务必手动commit(),否则数据不落盘 - 大批次建议分块(如每次 1000 行),避免单次请求超
max_allowed_packet(默认 4MB)导致Packets larger than max_allowed_packet bytes错误 - 如果用 ORM(如 SQLAlchemy),确认其批量方法是否真正生成多值
INSERT,有些版本会退化为循环单条










