Mysql-Insert插入过慢的原因记录和解决方案

 更新时间:2023年08月30日 15:34:11   作者:胡安民  
这篇文章主要介绍了Mysql-Insert插入过慢的原因记录和解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Mysql Insert插入过慢的原因

场景

先来说下业务场景, A单位每天下发全量数据5万数据左右,我们需要将这5万条数据处理到主表中以及日志表中

我们现在的逻辑是,先将数据每次100条批量修改或者插入到主表中, 然后我们通过事件监听将每次插入或者修改的动作都记录到日志表中

问题: 因为我们插入日志表的时候是每次处理一条这样就导致了5万条日志数据,一个一个插入非常耗时,抱着能提升一点就提升一点的想法,我们看看插入还能优化吗?

先来说一下: Mysql中单条语句原子性的,所以高并发情况下不会有安全性问题

说说插入会慢的影响因素

  • Mysql插入缓存(bulk_insert_buffer_size 默认是8M)
  • 每条数据在插入的时候都要验证是否违反表中的约束条件(主键,唯一等)
  • 构建新数据的索引
  • innodb中,数据通常都是先写缓存,再写事务日志,再写入数据文件
  • Mysql 每秒最大支持16384并发 ,但是默认只有151可以设置max_connections数量
  • 服务器性能,cpu,硬盘,网络, 网络数据传输 ,代码解析
  • 数据库事务影响

解决办法

先设置mysql的插入缓存bulk_insert_buffer_size=100M,确保一次能插入1000条数据

然后使用List方式记录需要插入的数据当达到1000条之后我们批量一次性插入

insert into tablename values('xxx','xxx'),('yyy','yyy'),('zzz','zzz')...... 

然后在清空List ,插入的过程中我们可以异步,不用等待结果的返回 ,通过上面的方案, 插入100万数据几十秒就完事了

为什么要这样解决呢?

因为批量插入其实就是访问一次数据量告诉数据库我需要执行这1000条的插入,而不是访问1000次数据库告诉数据库我要执行1条的插入所以使用批量插入大大的缩减客户端与数据库之间的连接、关闭等消耗 , 所以我们在上面的方案中使用一次提交批量数据的更新的语句,那么还有没其他的方式呢?

MySQL 的事务自动提交模式默认是开启的,其对 MySQL 的性能也有一定得影响。

也就是说如果你执行1000 条插入语句,MySQL 就会提交 1000 次事物,这大大影响了插入数据的速度。

我们还可以在代码中,手动开启事物也就是相当于希望事物内执行的语句要作为一个“不可分割”的整体去执行的任务当所有任务完毕后在提交事物,当然这样是没有批量插入快的但是也能节约不少时间的

MySQL数据库Insert语句慢SQL处理

问题描述

insert into …普通的插入语句,经常出现耗时2s以上

数据状态

1.表数据量大,每天产生200万条数据

2.高并发插入

问题解决

1.由于表中数据量庞大,建议数据归档处理,冷热处理

2.表中有过多索引,当数据insert时,索引会重排产生太多的io操作。导致缓慢,有必然要的只保留主键。

3.表的数据库引擎,默认InnerDB,若数据不重要,可以使用MyISAM

4.注意字段text使用,内存过大会引起表膨胀,影响插入和查询效率

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL可视化工具Navicat的连接方法

    MySQL可视化工具Navicat的连接方法

    今天小编就为大家分享一篇关于MySQL可视化工具Navicat的连接方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • Mysql存储过程如何实现历史数据迁移

    Mysql存储过程如何实现历史数据迁移

    这篇文章主要介绍了Mysql存储过程如何实现历史数据迁移,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 基于MySQL架构图解

    基于MySQL架构图解

    这篇文章主要介绍了基于MySQL架构图解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • mysql5.7数据库安装完成后如何配置环境变量

    mysql5.7数据库安装完成后如何配置环境变量

    这篇文章主要为大家详细介绍了在win10系统下,mysql5.7数据库安装完成后配置环境变量的具体步骤,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • MySQL 数据库如何实现存储时间

    MySQL 数据库如何实现存储时间

    这篇文章主要介绍了MySQL 数据库如何实现存储时间,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • MYSQL多表联查on和where的区别小结

    MYSQL多表联查on和where的区别小结

    在使用left join时过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多,本文就来详细介绍一下两者的区别,感兴趣的可以了解一下
    2023-11-11
  • MySQL如何通过Navicat实现远程连接

    MySQL如何通过Navicat实现远程连接

    这篇文章主要介绍了MySQL如何通过Navicat实现远程连接,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-09-09
  • Mac OS10.11下mysql5.7.12 安装配置方法图文教程

    Mac OS10.11下mysql5.7.12 安装配置方法图文教程

    这篇文章主要为大家详细介绍了Mac OS10.11下mysql5.7.12 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • 关于django连接mysql数据库并进行数据库的创建的问题

    关于django连接mysql数据库并进行数据库的创建的问题

    这篇文章主要介绍了django连接mysql数据库并进行数据库的创建,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 实例讲解MySQL统计库表大小

    实例讲解MySQL统计库表大小

    这篇文章主要介绍了MySQL统计库表大小的相关资料,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07

最新评论