mysql優(yōu)化 - MySQL如何為配置表建立索引?
問題描述
該配置表的結(jié)構(gòu)大致如下圖:
每次需要取出UID為ming的所有行,UID列最多不超過50個相同項(xiàng)(即一個UID可能有多條配置),是否有建立索引的必要?如果有必要建立索引,該如何建立?
希望能給些建議,謝謝!
問題解答
回答1:兩個問題建立索引的原則數(shù)據(jù)密度原則,數(shù)據(jù)密度是指列值唯一的記錄占總記錄數(shù)的百分比,這個比率越高,則說明此列越適合建立索引。反之,則不然。
經(jīng)常作為查詢條件的列,要考慮到建索引,提升查詢速度。
對于大表而且使用頻繁的表,在生產(chǎn)時最好不要去加索引; 如果對大表進(jìn)行索引,取出的數(shù)據(jù)大于總量的5%至10%,使用索引掃描會效率下降很多。如果通過索引,取出數(shù)據(jù)量為總量的50%以上,這個時候還不如全表掃描來得快。數(shù)據(jù)量小的表,使用不頻繁的不要單獨(dú)另建立索引;
在查詢條件中幾個條件一起使用的,適合建立組合索引,否則不要建立組合索引,當(dāng)單獨(dú)引用非第一字段時將發(fā)生全表掃描;
在查詢的時候,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 )
結(jié)論綜上所述,您的這個需求不適合建立索引。相關(guān)文章:
1. javascript - vscode alt+shift+f 格式化js代碼,通不過eslint的代碼風(fēng)格檢查怎么辦。。。2. javascript - [js]為什么畫布里不出現(xiàn)圖片呢?在線等3. python - 如何判斷爬蟲已經(jīng)成功登陸?4. html - vue項(xiàng)目中用到了elementUI問題5. html5 - 有可以一次性把所有 css外部樣式轉(zhuǎn)為html標(biāo)簽內(nèi)style=" "的方法嗎?6. javascript - 如何將一個div始終固定在某個位置;無論屏幕和分辨率怎么變化;div位置始終不變7. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?8. javascript - 有什么比較好的網(wǎng)頁版shell前端組件?9. javascript - 這不是對象字面量函數(shù)嗎?為什么要new初始化?10. javascript - 求解答:實(shí)例對象調(diào)用constructor,此時constructor內(nèi)的this的指向?
