如何在mysql中使用INSERT批量插入数据

批量插入可提升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 中的值一一对应。建议始终显式写出列名,避免因表结构变更导致错误。

例如:

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 可以有效提高插入效率,结合实际数据量选择合适方式即可。