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

13次阅读

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

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

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 IGNOREON 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 更关键。

text=ZqhQzanResources