MySQL批量插入和单条插入的性能

一、批量插入的实现方式

有两种实现方式:

1、开启一次数据库连接,在业务逻辑层用for循环,一条一条插入,关闭连接

<!-- 在外部for循环调用1000次 -->
<insert id="insert" parameterType="com.xxp.mybatis.Person">
    insert into person (id, name,sex,address)
    values 
    (#{id,jdbcType=INTEGER},#{name,jdbcType=VARCHAR},
    #{sex,jdbcType=VARCHAR},#{address,jdbcType=VARCHAR})
</insert>

2、sql语句:一次插入多条,例如下方sql:

 insert into table (id, name,sex,address)
 values
 (?,?,?,?),(?,?,?,?),(?,?,?,?),(?,?,?,?)

用mybatis实现就是:

<insert id="insertBatch" >
    insert into person (name,sex,address) 
    values 
    <foreach collection="list" item="item" index="index" separator=",">
        (#{item.name},#{item.sex},#{item.address})
    </foreach>
</insert>

二、由批量插入和单条插入的性能引起的反思

批量插入比一条一条的插入性能高原因如下:

  • 批量插入SQL执行效率高的主要原因是合并后日志量(MySQL的binlog和innodb的事务让日志)减少了,降低日志刷盘的数据量和频率,从而提高效率。通过合并SQL语句,同时也能减少SQL语句解析的次数,减少网络传输的IO。

ps:对于innodb,所有未提交的的二进制日志会被记录到一个缓存中去,等该事物提交时,直接将缓存中的二进制日志写入二进制日志文件中去,该缓存的大小由 binlog_cache_size决定,二进制日志记录了对MYSQL数据库执行更改的所有操作,但是不包括select和show这类操作,因为这类操作对数据本身并没有修改,二进制日志的功能:恢复,复制,审计。开启二进制当然会对性能有所影响,二进制日志并不是每次写的时候都同步到磁盘,参数sync_binlog表示多少次事物会从到磁盘中,如果是批量插入,表示只有1个事物

Mysql中常见的日志文件有:

  • 错误日志:对MySQL的启动,运行,关闭过程进行了记录

  • 二进制日志:j记录了对mysql数据库执行更改的所有操作,不包括select和show这种

  • 慢查询日志:可以在mysql启动时,设一个阈值,将运行时间超过该值的所有SQL语句都记录到慢查询日志文件中

  • 查询日志:记录了所有对mysql的请求信息

innodb存储引擎中的文件:

  • redolog

  • undolog

  • 表空间文件:innodb采用将存储的数据按表空间进行存放

Undo日志记录某数据被修改前的值,可以用来在事务失败时进行rollback;Redo日志记录某数据块被修改后的值,可以用来恢复未写入data file的已成功事务更新的数据。下面的示例来自于杨传辉《大数据分布式存储系统 原理解析与架构实践》,略作改动。

  • 例如某一事务的事务序号为T1,其对数据X进行修改,设X的原值是5,修改后的值为15,那么Undo日志为<T1, X, 5>,Redo日志为<T1, X, 15>。

二进制日志文件和redolog的区别:

  • 二进制日志会记录所有与mysql数据库有关的日志记录,包括其他存储引擎的日志,而redolog只记录innodb的

  • 二进制日志记录的是一个事物的具体操作内容,如update t set a=1,而redolog记录的是物理改变,如上述例子

  • 写入时间不同,二进制日志文件尽在事物提交前进行提交,而在事物进行的过程中,却不断的有重做日志被写入到重做日志文件中(因为重做日志记录的是改变,因此是在事物执行过程中记录每一个语句的改变,而二进制日志只是记录操作语句)

  • 1
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MySQL批量插入方法是一种在特定场景下使用的优化技术,相较于单次循环插入,具有较大的优势和应用价值。在MySQL中,批量插入可以有效地提高数据插入的速度和性能。根据引用和引用的描述,MySQL批量插入方法适用于以下场景: 1. 当需要一次性插入大量数据时,如导入Excel数据或处理大数据集。 2. 当需要提高插入性能和效率时,以减少数据库操作次数。 在实现过程中,可以按照以下步骤进行: 1. 在Controller层获取待导入的数据,并将其传递给后端处理。 2. 在mapper.xml文件中编写相应的SQL语句,用于批量插入数据。可以使用MySQL提供的批量插入函数,如`saveBatch()`,或者使用循环开启批处理模式。 3. 执行批量插入操作,将数据一次性插入数据库。 通过对常用的插入大数据的方式进行测试,可以得出比较实用的方案。根据引用的描述,常见的插入大数据的方式包括:for循环单条插入、拼接SQL语句、批量插入saveBatch()函数、循环开启批处理模式。根据实际需求和性能测试的结果,选择最适合的批量插入方式。 总结起来,MySQL批量插入方法是一种在特定场景下提高数据插入性能和效率的优化技术,可以根据具体需求选择合适的批量插入方式来实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [MySQL批量插入(使用mybatis实现mysql数据库批量插入操作)](https://blog.csdn.net/qq_43403676/article/details/124406698)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [MySQL优化:批量插入大数据4种实用、讲究方案的测试](https://blog.csdn.net/a18505947362/article/details/123667215)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悬浮海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值