位置: 编程技术 - 正文

MySQL分页优化(mysql大分页优化)

编辑:rootadmin

推荐整理分享MySQL分页优化(mysql大分页优化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 分页优化,mysql 分页优化,mysql uuid分页优化,mysql分页实现原理,mysql分页性能优化,mysql uuid分页优化,MySQL分页优化的其他方法,mysql分页性能优化,内容如对您有帮助,希望把文章链接给更多的朋友!

最近,帮同事重写了一个MySQL SQL语句,该SQL语句涉及两张表,其中一张表是字典表(需返回一个字段),另一张表是业务表(本身就有个字段,需全部返回),当然,字段的个数是否合理在这里不予评价。平时,返回的数据大概5w左右,系统尚能收到数据。但月日那天,数据量大概w,导致SQL执行时间过长,未能在规定的时间内反馈结果,于是系统直接报错。

一般的思路是用MySQL的分页功能,即直接在原SQL语句后面增加LIMIT子句。但请注意,虽然你看到的反馈结果只是LIMIT后面指定的数量,于是想当然的以为MySQL只是检索了指定数量的数据,然后给予返回。其实,MySQL内部实现的原理是,检索所有符合where条件的记录,然后返回指定数量的记录。从这个角度来看,直接在原SQL语句后面添加LIMIT子句只能说是一种可以实现功能的方案,但未必最优。

具体在本例中,首先我们来看一下个字段的表的统计信息:

一行大概就占2k,而Innodb默认页的大小为k,这意味着,一个页中最多可存储8行的数据。随机读的可能性大大增加。而这无疑会对数据库系统的IO造成极大的压力。

优化前

如果采用上述方案,即直接在原SQL语句后面增加LIMIT子句,下面,我们来看看它的执行情况。

首先,直接添加LIMIT子句后的SQL语句如下(已省略a1表的个字段和a2中的一个字段):

其执行时间如下:

大概执行了s,绝大部分都花费到Sending data上了。Sending data指的是服务器检索数据,读取数据,并将数据返回给客户端的时间。

关于上述执行结果,有以下几点需要说明:

1. 这是SQL语句多次执行后的结果,这样就可以排除结果缓存的影响,事实上,每次查询的时长都是s左右。

2. 为什么选用的是limit ,,而不是0,,这个主要是考虑到对于LIMIT子句来说,越到后面,分页的成本越高。基于此,选择了中间值来作为分页的结果。

该语句的执行计划如下:

优化后:

MySQL分页优化(mysql大分页优化)

优化的思路:

只对该表的主键进行分页,然后用返回的主键作为子查询的结果,来检索该表其它字段的值。

改写后的SQL语句如下:

其执行时间如下:

大概3s多,比第一种方案快了差不多倍,效果显著。

下面来看看其执行计划(explain extended)

总结:

1. 改写后的语句原本如下:

但MySQL报以下错误:

需再增加一个嵌套子查询,

比如这样的语句是不能正确执行的。

但是,只要你再加一层就行。如:

这样就可以绕开limit子查询的问题。 问题解决。

2. 如果想查看MySQL查询优化器等价改写后的SQL语句,可首先通过explain extended得到具体的执行计划,然后通过show warnings查看。

具体在本例中,等价改写后的SQL语句如下:

与设想中的执行顺序一致~

3. 如何查看MySQL语句各步骤的执行时间。

标签: mysql大分页优化

本文链接地址:https://www.jiuchutong.com/biancheng/321303.html 转载请保留说明!

上一篇:快速实现MySQL的部署以及一机多实例部署(mysql简单操作)

下一篇:如何恢复MySQL主从数据一致性(mysql怎么恢复数据)

  • 什么情况下纳税人和负税人一致
  • 产品分成方式取得收入什么意思举例
  • 房产税从价计征和从租怎么选择
  • 完税证明能作为理赔依据吗
  • 残保金申报在哪申报
  • 企业所得税季报可以更正吗
  • 结算金额大于合同金额
  • 银行抵债资产处置需要缴纳什么税费
  • 收到别人的承兑怎么入账
  • 营改增后装修材料如何抵扣?
  • 固定资产台账登记表明细科目写什么
  • 物业企业门禁卡如何记账?
  • 不再认证时段内
  • 收到银行退回的银行汇票多余款
  • 月初缴纳的保险是当月的吗
  • 帮客户垫付的费用有发票如何做账科目
  • 退回多交的所得税怎么做分录小规模
  • 企业承租经营的承租人取得的所得
  • 应交税费不核算
  • 小微企业减免所得税优惠政策
  • 孵化器 怎么赚钱
  • 确认并支付本年职工工资
  • 吸收合并具体分录
  • 境外取得收入要不要交企业所得税
  • 远期结汇账务处理分录
  • 企业合并无形资产摊销
  • 发出商品发生损失
  • 微信转账记录怎么加回好友?
  • 展位费一般多少钱
  • 红利所得的税法规定
  • _system~.ini 病毒
  • 微信公众平台开发
  • 委托代销视同买断会计分录怎么写?
  • php imagecopymerge
  • 个体工商户年报逾期怎么办
  • php缩进
  • 微信小程序最新咸鱼之王兑换
  • 总公司与分公司合作协议范本
  • 结算外单位收取的费用
  • 现代服务业主要功能
  • dict.setdefault()在python中设置默认值
  • 材料采购账户的借方登记什么
  • 金蝶固定资产累计折旧凭证生成
  • 小规模差额征税的账务处理
  • 个体工商户可以开增值税专用发票
  • mysql日期和时间分开存的 索引
  • 数据mysql
  • 生产工人工资结算表格模板
  • 收到社保局的稳岗通知
  • 其他业务支出的借贷方向
  • 租房期间损坏应赔偿多少
  • 欠钱打官司后利息怎么算
  • 简易计税的进项税额转出会计分录
  • 合伙企业是如何成立的
  • 应付职工社会保险费计入什么科目
  • 会计记账基础有哪两种
  • 免费获取windows8.1
  • win10预览版选哪个
  • 苹果怎样快速移动应用到其他桌面
  • win8平板触摸键盘没反应
  • win8如何切换用户登录
  • linux对比文件夹差异
  • win7系统电脑怎么连接wifi
  • win10系统网络连接配置异常
  • windows 8开机
  • cocos2dx解密
  • uisrollview
  • jquery输入框改变事件
  • jquery点击移动div
  • jQuery实现textarea自动增长宽高的方法
  • nodejs excel转json
  • jquery dom对象
  • python制作gui
  • Android ORM之GreenDao学习
  • springmvc返回json格式的注解
  • 土地增值税有哪些征收方式
  • 福建电子税务局社保缴费操作
  • 重庆国税电子税务局
  • 增值税专用发票电子版
  • 税务网上抄报流程是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设