iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中怎么优化批量SQL插入性能
  • 569
分享到

MySQL中怎么优化批量SQL插入性能

2024-04-02 19:04:59 569人浏览 安东尼
摘要

本篇文章为大家展示了Mysql中怎么优化批量sql插入性能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、一条SQL语句插入多条数据常用的插入语句如:INSERT

本篇文章为大家展示了Mysql中怎么优化批量sql插入性能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1、一条SQL语句插入多条数据

常用的插入语句如:

INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('0', 'userid_0', 'content_0', 0);  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('1', 'userid_1', 'content_1', 1);

修改成:

INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('0', 'userid_0', 'content_0', 0), ('1', 'userid_1', 'content_1', 1);

修改后的插入操作能够提高程序的插入效率。这里第二种SQL执行效率高的主要原因是合并后日志量(mysql的binlog和innodb的事务让日志)减少了,降低日志刷盘的数据量和频率,从而提高效率。通过合并SQL语句,同时也能减少SQL语句解析的次数,减少网络传输的io

这里提供一些测试对比数据,分别是进行单条数据的导入与转化成一条SQL语句进行导入,分别测试1百、1千、1万条数据记录。

MySQL中怎么优化批量SQL插入性能

2、在事务中进行插入处理

把插入修改成:

START TRANSACTION;  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('0', 'userid_0', 'content_0', 0);  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('1', 'userid_1', 'content_1', 1);  ...  COMMIT;

使用事务可以提高数据的插入效率,这是因为进行一个INSERT操作时,MySQL内部会建立一个事务,在事务内才进行真正插入处理操作。通过使用事务可以减少创建事务的消耗,所有插入都在执行后才进行提交操作。

这里也提供了测试对比,分别是不使用事务与使用事务在记录数为1百、1千、1万的情况。

MySQL中怎么优化批量SQL插入性能

3、数据有序插入

数据有序的插入是指插入记录在主键上是有序排列,例如datetime是记录的主键:

INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('1', 'userid_1', 'content_1', 1);  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('0', 'userid_0', 'content_0', 0);  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('2', 'userid_2', 'content_2',2);

修改成:

INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('0', 'userid_0', 'content_0', 0); INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('1', 'userid_1', 'content_1', 1);  INSERT INTO `insert_table` (`datetime`, `uid`, `content`, `type`)       VALUES ('2', 'userid_2', 'content_2',2);

由于数据库插入时,需要维护索引数据,无序的记录会增大维护索引的成本。我们可以参照InnoDB使用的B+tree索引,如果每次插入记录都在索引的最后面,索引的定位效率很高,并且对索引调整较小;如果插入的记录在索引中间,需要B+tree进行分裂合并等处理,会消耗比较多计算资源,并且插入记录的索引定位效率会下降,数据量较大时会有频繁的磁盘操作。

下面提供随机数据与顺序数据的性能对比,分别是记录为1百、1千、1万、10万、100万。

MySQL中怎么优化批量SQL插入性能

从测试结果来看,该优化方法的性能有所提高,但是提高并不是很明显。

4、性能综合测试

这里提供了同时使用上面三种方法进行INSERT效率优化的测试。

MySQL中怎么优化批量SQL插入性能

从测试结果可以看到,合并数据+事务的方法在较小数据量时,性能提高是很明显的,数据量较大时(1千万以上),性能会急剧下降,这是由于此时数据量超过了innodb_buffer的容量,每次定位索引涉及较多的磁盘读写操作,性能下降较快。而使用合并数据+事务+有序数据的方式在数据量达到千万级以上表现依旧是良好,在数据量较大时,有序数据索引定位较为方便,不需要频繁对磁盘进行读写操作,所以可以维持较高的性能。

注意事项:

  1.  SQL语句是有长度限制,在进行数据合并在同一SQL中务必不能超过SQL长度限制,通过max_allowed_packet配置可以修改,默认是1M,测试时修改为8M。

  2.  事务需要控制大小,事务太大可能会影响执行的效率。MySQL有innodb_log_buffer_size配置项,超过这个值会把innodb的数据刷到磁盘中,这时,效率会有所下降。所以比较好的做法是,在数据达到这个这个值前进行事务提交。 

上述内容就是MySQL中怎么优化批量SQL插入性能,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中怎么优化批量SQL插入性能

本文链接: https://www.lsjlt.com/news/56957.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中怎么优化批量SQL插入性能
    本篇文章为大家展示了MySQL中怎么优化批量SQL插入性能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、一条SQL语句插入多条数据常用的插入语句如:INSERT...
    99+
    2024-04-02
  • MySQL批量SQL插入的性能优化示例
    小编给大家分享一下MySQL批量SQL插入的性能优化示例,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!对于一些数据量较大的系统,数据库面临的问题除了查询效率低下,还有就是数据入库时间长。特别像...
    99+
    2024-04-02
  • MySQL大批量插入数据时怎么优化SQL语句
    这篇文章主要讲解了“MySQL大批量插入数据时怎么优化SQL语句”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL大批量插入数据时怎么优化SQL语句”...
    99+
    2024-04-02
  • SQL中怎么批量插入数据
    SQL中怎么批量插入数据,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.创建表。2.创建表值参数类型我们打开查询分析器,然后...
    99+
    2024-04-02
  • mysql批量插入性能优化:executeBatch如何通过rewriteBatchedStatements参数逆袭
    文章目录 前言一、实战演示1、单元测试2、不添加rewriteBatchedStatements参数3、添加rewriteBatchedStatements参数4、采用InsertBatchS...
    99+
    2023-09-04
    mybatis rewrite 批量写入 executeBatch 性能优化
  • Oracle中怎么优化大量数据插入的性能
    在Oracle中优化大量数据插入的性能,可以采取以下几种方法: 使用批量插入:使用INSERT INTO … SELECT语句将...
    99+
    2024-04-19
    Oracle
  • MySQL中怎么批量插入数据
    本篇文章为大家展示了MySQL中怎么批量插入数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.创建测试表mysql> show create table ...
    99+
    2024-04-02
  • Mysql中怎么实现批量插入
    本篇文章为大家展示了Mysql中怎么实现批量插入,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 1.创建测试表:create table...
    99+
    2024-04-02
  • MySQL怎么批量导入数据优化
    这篇文章将为大家详细讲解有关MySQL怎么批量导入数据优化,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 --MyISAM表my...
    99+
    2024-04-02
  • mysql中怎么批量导入sql文件
    mysql中怎么批量导入sql文件,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。有180个sql备份文件,批量导入首先新建一个...
    99+
    2024-04-02
  • mysql中怎么实现循环批量插入
    mysql中怎么实现循环批量插入,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。数据结构寻思着分页时标准列分主键列、索引列、普通列3种场景,...
    99+
    2024-04-02
  • mysql中怎么批量插入规律数据
    mysql中怎么批量插入规律数据,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Sql代码  insert into CPPRADAR( S...
    99+
    2024-04-02
  • mysql中怎么使用php批量插入数据
    这篇文章将为大家详细讲解有关mysql中怎么使用php批量插入数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  假如说我有这样一个表,我想往这个表里面插...
    99+
    2024-04-02
  • mysql的批量插入是什么
    这篇文章主要讲解了“mysql的批量插入是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql的批量插入是什么”吧!说明批量插入是一种逐条优化数据插入的方式。批量插入数据的语法类似于...
    99+
    2023-06-20
  • 如何解析MySQL性能优化中的SQL优化
    如何解析MySQL性能优化中的SQL优化,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注:以 MySQL 为背景,很多内容同时适用于其他关系型...
    99+
    2024-04-02
  • MyBatis中怎么实现批量插入
    这篇文章将为大家详细讲解有关MyBatis中怎么实现批量插入,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。plaincopy<insert ...
    99+
    2024-04-02
  • SQL Server性能怎么优化
    本篇内容主要讲解“SQL Server性能怎么优化”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL Server性能怎么优化”吧!数据库性能诊断和优化是提高数据库性能和稳定性的关键技术之一。...
    99+
    2023-06-27
  • MyBatis中怎么批量插入数据
    在MyBatis中,可以使用foreach标签来实现批量插入数据。具体步骤如下: 创建一个Mapper接口,定义一个insertB...
    99+
    2024-03-07
    MyBatis
  • Mysql 中怎么优化insert性能
    本篇文章为大家展示了Mysql 中怎么优化insert性能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Mysql优化之加速INSERT插入一条记录花费的时间由以下...
    99+
    2024-04-02
  • mysql中怎么优化插入记录速度
    mysql中怎么优化插入记录速度,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一. 对于MyISAM引擎表常见的优化方法如下:1. 禁用索引。...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作