如何一次插入多条数据_mysql批量insert写法

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

INSERT INTO logs_backup (user_id, action, created_at)
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 注入和类型错误。