MySQL:关于RR模式下insert..select sending data状态说明

作者:高鹏(网名八怪),《深入理解MySQL主从原理32讲》系列的作者。系列链接:https://www.jianshu.com/nb/43148932一、案例由来最近看到有人在问如下:...
摘要由CSDN通过智能技术生成

作者:高鹏(网名八怪),《深入理解MySQL主从原理32讲》系列的作者。

系列链接:https://www.jianshu.com/nb/43148932

一、案例由来

最近看到有人在问如下:

其中的sending data是什么意思。隔离级别为RR,语句为insert..select。

二、关于sending data

以前就说过这个问题,实际上sending data可能包含如下:

  • Innodb 层数据的定位返回给MySQL 层

  • Innodb 层数据的查询返回给MySQL 层

  • Innodb 层数据的修改(如果是insert..select)

  • Innodb 层加锁以及等待

  • 等待进入Innodb层(innodb_thread_concurrency参数)

  • MySQL 层发送数据给客户端

三、RR模式下对于insert..selcet 处于 sending data的原因总结

  • RR模式下insert..select的select表会上S行锁,如果这行处于X锁则会出现 sending data状态

  • insert..selcet中insert记录如果处于堵塞(唯一性检查)状态会处于 sending data状态

  • 整个过程如果需要操作的数据量较大,处于sending data状态。

四、每行数据处理方式

    929 T@4: | | | | | | THD::enter_stage: 'Sending data' /cdh/mysqldebug/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值