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

在 MySQL 中,使用 INSERT 语句批量插入数据可以显著提升插入效率,避免多次执行单条插入带来的性能开销。以下是几种常见的批量插入方式和使用建议。
1. 单条 INSERT 多行值
可以在一条 INSERT INTO ... VALUES 语句中插入多行数据,每行值用括号包裹,逗号分隔:
语法示例:
INSERT INTO users (name, age, email)
VALUES
('张三', 25, 'zhangsan@example.com'),
('李四', 30, 'lisi@example.com'),
('王五', 28, 'wangwu@example.com');
这种方式适合插入几十到几百条数据,性能优于多条单独的 INSERT。
2. 批量插入时注意字段安全
确保字段顺序与 VALUES 中的值一一对应。建议始终显式写出列名,避免因表结构变更导致错误。
例如:
网趣购物系统静态版支持网站一键静态生成,采用动态进度条模式生成静态,生成过程更加清晰明确,商品管理上增加淘宝数据包导入功能,与淘宝数据同步更新!采用领先的AJAX+XML相融技术,速度更快更高效!系统进行了大量的实用性更新,如优化核心算法、增加商品图片批量上传、谷歌地图浏览插入等,静态版独特的生成算法技术使静态生成过程可随意掌控,从而可以大大减轻服务器的负担,结合多种强大的SEO优化方式于一体,使
INSERT INTO products (title, price, stock)
VALUES
('手机', 2999.00, 50),
('耳机', 199.00, 200),
('充电器', 89.00, 100);
3. 控制批量大小
虽然一次插入越多越快,但需避免单条 SQL 过大:
- MySQL 有 max_allowed_packet 限制,默认通常为 4MB 或 16MB。
- 建议每批控制在 500~1000 条之间,平衡性能与稳定性。
- 超大批量可拆分为多个 INSERT 语句分批执行。
4. 使用 LOAD DATA INFILE(适用于大量数据)
如果要导入上万条数据,推荐使用 LOAD DATA INFILE,速度远高于 INSERT:
LOAD DATA INFILE '/path/to/data.csv' INTO TABLE users FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' (name, age, email);
此方法要求 CSV 文件存在于服务器端,且有文件读取权限。
基本上就这些。合理使用多行 INSERT 可以有效提高插入效率,结合实际数据量选择合适方式即可。









