技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> MySQL --> mysql索引的一个技巧

mysql索引的一个技巧

浏览:2564次  出处信息
针对select * from table where col1 > number order by col2 desc。

其实按照常规的方法可以这样设计:key(col1, col2)

但是这种办法在mysql里不算是理想的,where条件里限定索引前部分是一个范围的情况下后面的order by还是会有filesort。如果where条件里限定索引前部分是一个常量,那么order by就会有效利用索引。例如:select * from table where col1 = number order by col2 desc,explain的结果就不错。

为了让它能够利用上索引并且消除filesort,可以这样设计
索引:key(col2,col1);
select * from table where col2 > min_value and col1 > number order by col2 desc;
这里where条件里同时执行了索引的两个列,并且为了保证逻辑一致,对col2列的限定条件等效于无限定。

这样mysql就能很好的利用索引了。这个技巧在mysql high performance2里也有提过

建议继续学习:

  1. 由浅入深探究mysql索引结构原理、性能分析与优化    (阅读:14945)
  2. 浅谈MySQL索引背后的数据结构及算法    (阅读:9861)
  3. 由浅入深理解索引的实现(2)    (阅读:6315)
  4. HBase二级索引与Join    (阅读:5764)
  5. 如何建立合适的索引?    (阅读:5334)
  6. InnODB和MyISAM索引统计集合    (阅读:5161)
  7. Innodb 表和索引结构    (阅读:4774)
  8. mysql查询中利用索引的机制    (阅读:4686)
  9. MySQL索引背后的数据结构及算法原理    (阅读:4402)
  10. 多维度分类排行榜应用:用位图索引    (阅读:4003)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1