mysql如何插入多条数据_mysql batch insert语法示例

来源:这里教程网 时间:2026-02-28 20:46:21 作者:

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
,有些版本会退化为循环单条
实际批量插入的瓶颈往往不在语法本身,而在事务粒度、索引维护开销、以及网络往返次数——这些比选哪条 SQL 更关键。

相关推荐