mysql 字段索引的问题
问题描述
在sf看到篇文章里面有这么一段关于数据表索引的
KEY `idx_status_date` (`status`,`date`)
我想问下 上面的写法 和下面的写法 有什么区别么?
KEY `status` (`status`),KEY `date` (`date`)
问题解答
回答1:一个是组合索引 一个单个字段建立索引 建议你搜索下 组合索引和单个索引类似的文章,主要这个问题解释起来文字太多,你自己去看下网上资料!
回答2:组合索引跟单字段索引有很大不同 , 组合索引有顺序的组合索引对于搜索条件为
status = 0 AND date= 'XXXX'或者status = 0这两种情况都有效
但是对于date='XXX'的话就没什么用了而且组合索引只能有一个范围搜索,这个如果要说起码要很长, 抽空看看'高性能MySQL'吧 , 里面有介绍
回答3:KEY idx_status_date (status,date)组合索引能说为组合,当然是组合使用的使用才能最大生效第一,组合索引必定有顺序之分就像上面那个,status和date作为组合索引在where status = ’1’ and date = ’2017-01-01’的时候,组合索引就会生效。但假如你的搜索条件中,date在status前面,那么索引只会生效一部分因为mysql检测到status作为索引,但无法使用date索引
而单个索引就更好理解只有你搜索字段哪个建立索引,哪个生效
你可以使用explian 看mysql语句索引使用情况
相关文章:
1. mongodb - windows7下mongod无法正常启动2. 修改mysql配置文件的默认字符集重启后依然不生效3. mysql中的全文索引支持词根检索吗?4. Python两个list互换,两种不同的操作结果有差异,原因是什么呢?5. MySQL视图count速度优化6. php - 类似Apple官网顶部3级导航该如何设计数据库?7. android-studio - Android Studio logcat一闪而过,如何显示出来8. mysql - 请教一个Java做数据库缓存的问题9. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战10. javascript - ueditor引入报错问题

网公网安备