批量插入可提升mysql效率,推荐单条INSERT多行值方式,每批500~1000条,显式指定字段名确保安全,超大量数据宜用LOAD DATA INFILE。

在 MySQL 中,使用 INSERT 语句批量插入数据可以显著提升插入效率,避免多次执行单条插入带来的性能开销。以下是几种常见的批量插入方式和使用建议。
1. 单条 INSERT 多行值
可以在一条 INSERT INTO … VALUES 语句中插入多行数据,每行值用括号包裹,逗号分隔:
语法示例:
<font face="Courier New" size="2">INSERT INTO users (name, age, email) VALUES ('张三', 25, 'zhangsan@example.com'), ('李四', 30, 'lisi@example.com'), ('王五', 28, 'wangwu@example.com');</font>
这种方式适合插入几十到几百条数据,性能优于多条单独的 INSERT。
2. 批量插入时注意字段安全
确保字段顺序与 VALUES 中的值一一对应。建议始终显式写出列名,避免因表结构变更导致错误。
例如:
<font face="Courier New" size="2">INSERT INTO products (title, price, stock) VALUES ('手机', 2999.00, 50), ('耳机', 199.00, 200), ('充电器', 89.00, 100);</font>
3. 控制批量大小
虽然一次插入越多越快,但需避免单条 SQL 过大:
- MySQL 有 max_allowed_packet 限制,默认通常为 4MB 或 16MB。
- 建议每批控制在 500~1000 条之间,平衡性能与稳定性。
- 超大批量可拆分为多个 INSERT 语句分批执行。
4. 使用 LOAD DATA INFILE(适用于大量数据)
如果要导入上万条数据,推荐使用 LOAD DATA INFILE,速度远高于 INSERT:
<font face="Courier New" size="2">LOAD DATA INFILE '/path/to/data.csv' INTO TABLE users FIELDS TERMINATED BY ',' LINES TERMINATED BY 'n' (name, age, email);</font>
此方法要求 CSV 文件存在于服务器端,且有文件读取权限。
基本上就这些。合理使用多行 INSERT 可以有效提高插入效率,结合实际数据量选择合适方式即可。