mysql 字段索引的問題
問題描述
在sf看到篇文章里面有這么一段關(guān)于數(shù)據(jù)表索引的
KEY `idx_status_date` (`status`,`date`)
我想問下 上面的寫法 和下面的寫法 有什么區(qū)別么?
KEY `status` (`status`),KEY `date` (`date`)
問題解答
回答1:一個是組合索引 一個單個字段建立索引 建議你搜索下 組合索引和單個索引類似的文章,主要這個問題解釋起來文字太多,你自己去看下網(wǎng)上資料!
回答2:組合索引跟單字段索引有很大不同 , 組合索引有順序的組合索引對于搜索條件為
status = 0 AND date= 'XXXX'或者status = 0這兩種情況都有效
但是對于date='XXX'的話就沒什么用了而且組合索引只能有一個范圍搜索,這個如果要說起碼要很長, 抽空看看'高性能MySQL'吧 , 里面有介紹
回答3:KEY idx_status_date (status,date)組合索引能說為組合,當(dāng)然是組合使用的使用才能最大生效第一,組合索引必定有順序之分就像上面那個,status和date作為組合索引在where status = ’1’ and date = ’2017-01-01’的時候,組合索引就會生效。但假如你的搜索條件中,date在status前面,那么索引只會生效一部分因為mysql檢測到status作為索引,但無法使用date索引
而單個索引就更好理解只有你搜索字段哪個建立索引,哪個生效
你可以使用explian 看mysql語句索引使用情況
相關(guān)文章:
1. android - weex 項目createInstanceReferenceError: Vue is not defined2. PHPExcel表格導(dǎo)入數(shù)據(jù)庫怎么導(dǎo)入3. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點4. pdo 寫入到數(shù)據(jù)庫的內(nèi)容為中文的時候?qū)懭雭y碼5. javascript - 如圖,百度首頁,查看源代碼為什么什么都沒有?6. vue2.0+webpack 如何使用bootstrap?7. PHP類封裝的插入數(shù)據(jù),總是插入不成功,返回false;8. mac連接阿里云docker集群,已經(jīng)卡了2天了,求問?9. javascript - 前端開發(fā)框架express,在他的模板引擎下怎么給按鈕添加綁定事件?10. 請問PHPstudy中的數(shù)據(jù)庫如何創(chuàng)建索引
