mysql快速插入大量数据的正确方法

 更新时间:2024年01月15日 10:44:25   作者:菜鸟_cc  
在处理大量数据时如果一条一条地插入会极大地影响效率,因此批量插入是一个更好的选择,下面这篇文章主要给大家介绍了关于mysql快速插入大量数据的正确方法,需要的朋友可以参考下

前言

最近做性能测试,需要模拟生产环境的数据量,在造百万、千万级数据的时候发现直接使用插入sql效率极低,百度了一翻,找到几种方式,但用下来还是有很快速的方式,推荐第四种

插入mysql数据效率对比

1.单行插入

insert into tableName (colunm1,colunm2,...) value(value1,value2,...);

没错,很普通的一条sql,插入速度也很普通,不推荐

2.多行插入

insert into tableName(colunm1,colunm2,..) values(value1,value2...),(value1,value2...);

有点点进度,但是不多,多行插入可以减少插入数据时的IO和网络开销,从而加快插入数据的速度。此方法适用于插入少量数据的情况,当插入数据量变大时,数据库连接可能会被打满

3.批量插入

INSERT INTO table_name (column1, column2, column3)
VALUES
(value1, value2, value3),
(value4, value5, value6),
......
ON DUPLICATE KEY UPDATE column1=VALUES(column1), column2=VALUES(column2), column3=VALUES(column3);

这个操作将所有插入放在一个事务中,并将其视为一个操作。此方法使用一次SQL查询来插入大量数据,因此减少了IO和网络开销

4.使用LOAD DATA INFILE语句

LOAD DATA INFILE 'file_name'
INTO TABLE table_name
FIELDS TERMINATED BY ','
LINES TERMINATED BY '\n';

使用LOAD DATA INFILE语句可以将大量的数据快速地导入MySQL中。此方法适用于数据已存储在文件中的情况,您只需指定文件名和目标表即可导入数据。而且,此方法支持多线程操作,可在不阻塞数据库的同时并行地导入数据

说实话,这种方式非常香,亲测500W数据1分钟插入完成,推荐file_name: 本地存储数据的文件

这个文件的数据需要先准备好,你也可以选择像我一样代码生成

  • 首先,从数据库复制一条数据

  • 然后把复制出来的插入sql中value里的内容抠出来
  • 抠出来的内容注意下是否有外键、主键,如果有要处理一下扣出来的内容,下面的例子是id是主键,我给去掉了,然后循环生成主键拼接上去,循环生成的值要符合数据库的字段定义类型
data = ",860272,'2023-07-26 18:00:03','2023-07-26 18:00:03',1,未完成,时,1,1时,219,85,1,001-001,0,9784,'2023-07-26 18:00:03',9784,'2023-07-26 18:00:03'"
with open('demo.txt', 'w+', encoding='utf-8') as f:
    for i in range(0, 1000000):
        f.write(str(i + 1) + data + '\n')
  • 执行后生成demo.txt文件,每一行不同的值逗号分隔

  • 最后,连接数据库,可以使用命令连接,也可以借助工具连接,执行命令
LOAD DATA LOCAL INFILE 'E:\\demo.txt' INTO TABLE 表名
FIELDS TERMINATED BY ',' ('列名1','列名2','列名3','列名4')

注意:你的txt的值要跟命令中的列名对应上,如果你是全字段的值插入,那么('列名1','列名2','列名3','列名4')可以省略不写

好了,可以享受插入数据的快乐了…

总结

到此这篇关于mysql快速插入大量数据的正确方法的文章就介绍到这了,更多相关mysql快速插入大量数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要区别整理

    MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要区别整理

    这篇文章主要介绍了MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要区别整理,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-08-08
  • MySQL批量SQL插入性能优化详解

    MySQL批量SQL插入性能优化详解

    这篇文章主要为大家详细介绍了MySQL批量SQL插入性能优化,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • MySQL8中隐藏索引与降序索引的新特性

    MySQL8中隐藏索引与降序索引的新特性

    本文主要介绍了MySQL8中隐藏索引与降序索引的新特性,隐藏索引和降序索引为数据库的性能优化和灵活性提供了有力支持,感兴趣的可以了解一下
    2024-08-08
  • MySQL redo死锁问题排查及解决过程分析

    MySQL redo死锁问题排查及解决过程分析

    被告知在多实例场景下 MySQL Server hang 住,无法测试下去,原生版本不存在这个问题,而新版本上出现了这个问题,不禁心头一颤,心中不禁感到奇怪,还好现场环境还在,为排查问题提供了一个好的环境,随即便投入到紧张的问题排查过程当中
    2016-10-10
  • 解决MySql不等于的条件过滤字段值为NULL问题

    解决MySql不等于的条件过滤字段值为NULL问题

    今天遇到一个查询结果不对的问题,使用isNull能解决问题,但因查询条件过滤null,还有不同的写法,总结了两种实现方式,希望能给大家一个参考
    2024-12-12
  • 解决MySQL无法远程连接的方法

    解决MySQL无法远程连接的方法

    这篇文章主要介绍了解决MySQL无法远程连接的方法,文中给出的解决方案主要针对IP限制时出现的该种情况,需要的朋友可以参考下
    2015-04-04
  • Mysql常用运算符与函数汇总

    Mysql常用运算符与函数汇总

    本文给大家汇总介绍了mysql中的常用的运算符以及常用函数的用法及示例,非常的全面,有需要的小伙伴可以参考下
    2017-09-09
  • MySQL主从延迟问题解决

    MySQL主从延迟问题解决

    这篇文章主要介绍了MySQL主从延迟问题解决的方法,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2021-01-01
  • MySQL5.6.31 winx64.zip 安装配置教程详解

    MySQL5.6.31 winx64.zip 安装配置教程详解

    这篇文章主要介绍了MySQL5.6.31 winx64.zip 安装配置教程详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • 避免MySQL中的隐式转换的方法小结

    避免MySQL中的隐式转换的方法小结

    在 MySQL 中,隐式转换可能导致索引失效、结果不符合预期或性能问题,以下是避免隐式转换的具体方法,从表设计、查询编写到配置优化,逐步减少隐式转换的发生,具体操作过程跟随小编一起看看吧
    2025-04-04

最新评论