0

0

如何插入多条数据_mysql批量插入技巧

P粉602998670

P粉602998670

发布时间:2026-01-22 09:51:24

|

700人浏览过

|

来源于php中文网

原创

MySQL批量插入多条数据的核心是单条INSERT多值语法,如INSERT INTO users VALUES (...),(...),(...);还可结合LOAD DATA INFILE快速导入大文件、显式事务控制(每1000–5000行提交)、INSERT...SELECT表间复制等方式提升效率。

如何插入多条数据_mysql批量插入技巧

MySQL 批量插入多条数据,核心是用一条 INSERT INTO ... VALUES (...), (...), (...) 语句代替多次单条插入,能显著提升性能、减少网络往返和事务开销。

使用单条 INSERT 多值语法

这是最常用、最直接的批量插入方式。语法是在 VALUES 后连续列出多组括号,每组对应一行数据:

INSERT INTO users (name, age, email) VALUES
  ('张三', 25, 'zhangsan@example.com'),
  ('李四', 30, 'lisi@example.com'),
  ('王五', 28, 'wangwu@example.com');

  • 一次最多可插入约 1000 行(受 max_allowed_packet 和行长度限制)
  • 所有值必须类型匹配,且列顺序与 INSERT INTO 指定列一致
  • 避免在循环中拼接大量值——应先在应用层组装好再执行

利用 LOAD DATA INFILE 快速导入大文件

当数据来自 CSV 或文本文件且量较大(万级以上),LOAD DATA INFILE 比 INSERT 快数倍:

LOAD DATA INFILE '/tmp/users.csv'
INTO TABLE users
FIELDS TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\n'
(name, age, email);

网趣网上购物系统HTML静态版
网趣网上购物系统HTML静态版

网趣购物系统静态版支持网站一键静态生成,采用动态进度条模式生成静态,生成过程更加清晰明确,商品管理上增加淘宝数据包导入功能,与淘宝数据同步更新!采用领先的AJAX+XML相融技术,速度更快更高效!系统进行了大量的实用性更新,如优化核心算法、增加商品图片批量上传、谷歌地图浏览插入等,静态版独特的生成算法技术使静态生成过程可随意掌控,从而可以大大减轻服务器的负担,结合多种强大的SEO优化方式于一体,使

下载
  • 要求 MySQL 有文件读取权限(或使用 LOCAL 关键字配合客户端支持)
  • 需确保字段分隔符、换行符、引号格式与文件实际一致
  • 可配合 IGNOREREPLACE 处理重复主键/唯一键冲突

结合事务控制提升效率

即使使用批量 INSERT,若每条语句自动提交,仍会频繁刷盘。显式事务能大幅减少 I/O:

START TRANSACTION;
INSERT INTO logs (msg, created_at) VALUES
  ('error-1', NOW()), ('warn-1', NOW()), ('info-1', NOW());
INSERT INTO logs (msg, created_at) VALUES
  ('error-2', NOW()), ('warn-2', NOW());
COMMIT;

  • 建议每 1000–5000 行提交一次,平衡内存占用与崩溃恢复成本
  • 避免超长事务导致锁表时间过久或 binlog 过大
  • 注意:MyISAM 不支持事务,但也能通过禁用索引(ALTER TABLE ... DISABLE KEYS)优化

用 INSERT ... SELECT 实现表间批量复制

从已有表中筛选并插入到目标表,适合 ETL 场景或数据归档:

INSERT INTO archive_orders (order_id, amount, status, archived_at)
SELECT id, total, 'done', NOW()
FROM orders WHERE status = 'completed' AND created_at

  • 支持 WHEREJOIN、函数计算等复杂逻辑
  • 可加 ON DUPLICATE KEY UPDATE 处理目标表已存在记录的情况
  • 大数据量时建议加索引加速源表过滤,必要时分批执行(如按 ID 范围)

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

664

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

255

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

530

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

600

2023.08.14

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

1

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 805人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号