高性能Mysql07-查询性能优化

为什么查询速度为慢

查询性能低最基本的原因是访问的数据太多。

重构查询的方式

  • 一个复杂查询还是多个简单查询:
    设计查询的时候一个需要考虑的问题是,是否需要将一个复杂的查询拆分成多个简单查询。在Mysql中运行多个小查询不是问题
  • 切分查询:
    【案例】:定期清除大量的数据。
    如果用一个sql一次删除数据的话,则可能需要一次锁住很多数据,占满整个事务日志,耗尽系统资源,阻塞很多小但重要的查询。
    解决办法:可以通过控制一次性删除1万条数据,多次删除。
    【注】 一次性删除1万条数据一般来说是一个比较高效的而且对服务器影响也最小的做法(如果是事务型引擎,很多时候小事务能够更高效——在批量插入大量数据时,注意一次事务提交的数据量,过大或者过小都会导致性能变低。
  • 分解关联查询
    当表数据量很大时,对表做关联查询就会很慢,少一个关联 性能都会有很大的提升。
    对于一个sql中的关联查询(join)可以拆分为多个查询语句,在程序中进行关联(Java代码),在数据量大的情况下,性能将会提升几个数量级。
    分解关联查询的优点
    (1)让缓存的效率更高:我们可以在程序代码中将基础查询(数据量不大)的查询缓存起来,要用的时候直接取。
    (2)将查询分解后,执行单个查询可以减少锁的竞争。
    (3)在应用层做关联,可以更容易对数据库进行拆分,更容易做到高性能和可扩展。
    (4)查询本身效率也可能有所提升。
    (5)可以减少冗余记录的查询。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值