关于mysql索引的一些总结

转自深入浅出mysql
1.定位效率较低的sql语句
(1)通过慢查询定位执行效率较低的sql语句
(2)使用show processlist命令查看当前mysql在进行的线程,包括线程的状态,是否锁表等

2.通过explain分析低效的sql执行计划
3.索引使用
(1)索引的前缀特性
如果索引是一个组合索引如(status,time),那么当使用status做为查询条件时,索引仍然有效;如果查询条件是time,那么索引就无效
(2)对于使用like的查询,后面如果是常量并且只有%号不在第一个字符,索引才可能会被使用,如%xxx就不能用到索引,xxx%才能用到索引
(3)如果列名是索引,使用column_name is null将使用索引
(4)如果使用or分割条件,那么 只有or前后的列都用到索引,这条语句才会用到索引
(5)如果列类型是字符串,那么一定在where条件中把字符常量值用引号引起来,否则即便这个列上有索引,mysql也不会用到
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值