MySQL中最常用高效的多条数据插入方式是单条INSERT语句配合多组VALUES,如INSERT INTO users (name,age,city) VALUES('张三',25,'北京'),('李四',30,'上海');字段顺序须一致,NULL或DEFAULT需显式写出,单次建议≤1000行并配合事务提升性能。
MySQL 中一次插入多条数据,最常用也最高效的方式就是用单条 INSERT 语句配合多组值,也就是批量插入(Bulk Insert)。
标准批量 INSERT 语法
核心写法是:在 VALUES 后面跟上多个用逗号分隔的括号,每个括号内是一行数据的字段值。
示例:
INSERT INTO users (name, age, city) VALUES('张三', 25, '北京'),
('李四', 30, '上海'),
('王五', 28, '广州'),
('赵六', 32, '深圳');
这样一条语句就插入了 4 行数据,比执行 4 次单条 INSERT 快得多,也减少了网络往返和事务开销。
注意事项和实用建议
-
字段顺序必须一致:每组括号内的值顺序要严格对应
INSERT INTO ... (col1, col2, col3)中声明的列顺序。 -
NULL 或默认值要显式写出:比如某行 name 为空,写成
(NULL, 26, '杭州');如果想用默认值(如设置了DEFAULT CURRENT_TIMESTAMP),可写(DEFAULT, 26, '杭州')。 -
单次插入不宜过多:虽然 MySQL 支持大批次,但受
max_allowed_packet限制(默认一般 4MB)。建议单次控制在 1000 行以内,更稳妥可分 500 行一批。 -
配合事务提升性能:如果一次插几千上万行,先
BEGIN,再批量插入,最后COMMIT,能显著减少日志刷盘次数。
其他常见场景补充
从另一张表导入数据:可用 INSERT ... SELECT
SELECT user_id, action, created_at FROM logs WHERE created_at
忽略重复或替换已有记录:
- 用
INSERT IGNORE跳过主键/唯一键冲突的行; - 用
REPLACE INTO先删后插(慎用,会触发删除动作); - 用
INSERT ... ON DUPLICATE KEY UPDATE实现“存在则更新,不存在则插入”。
程序中拼接批量 SQL 的小
提醒
代码里动态生成多值时,注意:
- 不要手拼 SQL 字符串防注入,优先用预处理(如 Python 的
executemany()、Java 的PreparedStatement.addBatch()); - 若必须拼接,确保每个值都正确转义或使用参数占位符(
?或%s),避免 SQL 注入和类型错误。

提醒






