mysql優化 - MySQL如何為配置表建立索引?
問題描述
該配置表的結構大致如下圖:
每次需要取出UID為ming的所有行,UID列最多不超過50個相同項(即一個UID可能有多條配置),是否有建立索引的必要?如果有必要建立索引,該如何建立?
希望能給些建議,謝謝!
問題解答
回答1:兩個問題建立索引的原則數據密度原則,數據密度是指列值唯一的記錄占總記錄數的百分比,這個比率越高,則說明此列越適合建立索引。反之,則不然。
經常作為查詢條件的列,要考慮到建索引,提升查詢速度。
對于大表而且使用頻繁的表,在生產時最好不要去加索引; 如果對大表進行索引,取出的數據大于總量的5%至10%,使用索引掃描會效率下降很多。如果通過索引,取出數據量為總量的50%以上,這個時候還不如全表掃描來得快。數據量小的表,使用不頻繁的不要單獨另建立索引;
在查詢條件中幾個條件一起使用的,適合建立組合索引,否則不要建立組合索引,當單獨引用非第一字段時將發生全表掃描;
在查詢的時候,where條件不要對索引的列做處理,而要對后面的條件字段做處理。否則用不上這個列上的索引。
如何建立索引添加普通索引:ALTER TABLE table_name ADD INDEX index_name ( column )
添加主鍵索引:ALTER TABLE table_name ADD PRIMARY KEY ( column )
添加唯一索引:ALTER TABLE table_name ADD UNIQUE ( column )
添加全文索引:ALTER TABLE table_name ADD FULLTEXT ( column)
添加多列索引:ALTER TABLE table_name ADD INDEX index_name ( column1, column2, column3 )
結論綜上所述,您的這個需求不適合建立索引。相關文章:
1. javascript - vuejs+elementui 購物車價格計算,點擊加減號修改數量總價都不會改變,但是計算執行了2. css右浮動字的順序顛倒了3. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)4. html5和Flash對抗是什么情況?5. javascript - 我是做web前端的,公司最近有一個項目關于數據統計的!6. ios - 類似微博首頁,一張圖的時候是如何確定圖大小的?7. javascript - 如何使用loadash對[object,object,object]形式的數組進行比較8. javascript - vue過渡效果 css過渡 類名的先后順序9. javascript - 在ie下為什么會出現這種情況呢 《 無法獲取未定義或 null 引用的屬性“length”》 ?請大神指教。10. 數據庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。
