• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL 联合索引与Where子句的优化 提高数据库运行效率

MySQL 联合索引与Where子句的优化 提高数据库运行效率

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了联合索引等相关知识,希望本文的分享对您有所帮助

网站系统上线至今,数据量已经不知不觉上到500M,近8W记录了。涉及数据库操作的基本都是变得很慢了,这篇文章主要是说明配置并不是数据库操作慢的主要原因

网站系统上线至今,数据量已经不知不觉上到500M,近8W记录了。涉及数据库操作的基本都是变得很慢了,用的人都会觉得躁火~~然后把这个情况在群里一贴,包括机器配置什么的一说,马上就有群友发话了,而且帮我确定了不是机器配置的问题,“深圳-枪手”热心人他的机器512内存过百W的数据里也跑得飞快,甚至跟那些几W块的机器一样牛(吹过头了),呵呵~~~

  在群友的分析指点下,尝试把排序、条件等一个一个去除来做测试,结果发现问题就出在排序部分,去除排序的时候,执行时间由原来的48秒变成0.3x秒,这是个什么档次的变化呀~~看着这个结果我激动ing.....

  于是我把涉及排序的字段组成一个联合索引alter table xx add index indexname(x1,x2,x3),经过2分钟创建新索引之后再执行同一个SQL语句,哇塞0.28S。。。。爽

  于是按照同样的思路把其它几个常用的SQL作了过些优化,效果马上见效

  过了30分钟再查slow sql记录文件,不好了,发现原来一个好好的SQL变得灰常慢了,神马情况?

  几经分析和测试原来就是因为添加了联合索引的原因,而且这个SQL语句当中有个or,当把这个or改用union之后问题排除。

  这回又得出一个心得:写SQL的时候千万别一时就手,随便写个就OK,那会为以为带来很严重的后果。

  再附上一段关于Where子句的执行顺序:

  在用MySQL查询数据库的时候,连接了很多个用,发现非常慢。例如:

  SELECT ... WHERE p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1 AND p.products_id IN (472,474)

  这样查询需要20多秒,虽然在各个字段上都建立了索引。用分析Explain SQL一分析,发现在第一次分析过程中就返回了几万条数据:

  WHERE p.languages_id = 1 ,然后再依次根据条件,缩小范围。

  而我改变一下WHERE 字段的位置之后,速度就有了明显地提高:

  WHERE p.products_id IN (472,474) AND p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1

  这样,第一次的条件是p.products_id IN (472,474),它返回的结果只有不到10条,接下来还要根据其它的条件来过滤,自然在速度上有了较大的提升。

  经过实践发现,不要以为WHERE中的字段顺序无所谓,可以随便放在哪,应该尽可能地第一次就过滤掉大部分无用的数据,只返回最小范围的数据。

  希望能帮到有同样遭遇的朋友。
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2018-12-05EXCEL与MySQL日期格式转换
  • 2017-05-11JDBC数据库的使用操作总结
  • 2018-12-05高效的MySQL的批插入 BULK INSERT
  • 2018-12-05Access数据库出现“无法保存;正被别的用户锁定”的原因
  • 2018-12-05MySQL优化之-备份和恢复代码详解(图)
  • 2017-05-11mysql登录遇到ERROR 1045问题解决方法
  • 2018-12-05从一个serialize过的array的字符串中取出中取对应KEY的value
  • 2018-12-05sqlserver 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)
  • 2018-12-05MySQL视图的应用之修改视图
  • 2018-12-05自动备份Oracle数据库

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL分表自增ID问题的解决方法_MySQL
    • Java中如何实现对象的序列化和反序列化?(两种方法)
    • 如何理解spring事务及声明式事务的使用
    • sql2000 卸载后重新安装时不能安装的解决办法
    • mongodb 3.4下远程连接认证失败应该怎么办?
    • 通过SQLServer 2008 操作 MySQL的方法
    • Microsoft Search 服务无法启动 解决办法.
    • Oracle 11g2的监听器配置教程
    • TRUNCATE 快速删除表中的所有数据
    • Mysql表的七种类型详细介绍

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有