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

在 MySQL 中,使用 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。
确保字段顺序与 VALUES 中的值一一对应。建议始终显式写出列名,避免因表结构变更导致错误。
例如:
<font face="Courier New" size="2">INSERT INTO products (title, price, stock)
VALUES
('手机', 2999.00, 50),
('耳机', 199.00, 200),
('充电器', 89.00, 100);</font>虽然一次插入越多越快,但需避免单条 SQL 过大:
如果要导入上万条数据,推荐使用 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 可以有效提高插入效率,结合实际数据量选择合适方式即可。
以上就是如何在mysql中使用INSERT批量插入数据的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号