mysql優(yōu)化 - MySQL如何為配置表建立索引?
問(wèn)題描述
該配置表的結(jié)構(gòu)大致如下圖:
每次需要取出UID為ming的所有行,UID列最多不超過(guò)50個(gè)相同項(xiàng)(即一個(gè)UID可能有多條配置),是否有建立索引的必要?如果有必要建立索引,該如何建立?
希望能給些建議,謝謝!
問(wèn)題解答
回答1:兩個(gè)問(wèn)題建立索引的原則數(shù)據(jù)密度原則,數(shù)據(jù)密度是指列值唯一的記錄占總記錄數(shù)的百分比,這個(gè)比率越高,則說(shuō)明此列越適合建立索引。反之,則不然。
經(jīng)常作為查詢(xún)條件的列,要考慮到建索引,提升查詢(xún)速度。
對(duì)于大表而且使用頻繁的表,在生產(chǎn)時(shí)最好不要去加索引; 如果對(duì)大表進(jìn)行索引,取出的數(shù)據(jù)大于總量的5%至10%,使用索引掃描會(huì)效率下降很多。如果通過(guò)索引,取出數(shù)據(jù)量為總量的50%以上,這個(gè)時(shí)候還不如全表掃描來(lái)得快。數(shù)據(jù)量小的表,使用不頻繁的不要單獨(dú)另建立索引;
在查詢(xún)條件中幾個(gè)條件一起使用的,適合建立組合索引,否則不要建立組合索引,當(dāng)單獨(dú)引用非第一字段時(shí)將發(fā)生全表掃描;
在查詢(xún)的時(shí)候,where條件不要對(duì)索引的列做處理,而要對(duì)后面的條件字段做處理。否則用不上這個(gè)列上的索引。
如何建立索引添加普通索引: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é)論綜上所述,您的這個(gè)需求不適合建立索引。相關(guān)文章:
1. python - sqlalchemy更新數(shù)據(jù)報(bào)錯(cuò)2. 運(yùn)行python程序時(shí)出現(xiàn)“應(yīng)用程序發(fā)生異?!钡膬?nèi)存錯(cuò)誤?3. javascript - h5微信中怎么禁止橫屏4. macos - 無(wú)法source activate python275. empty比isset更嚴(yán)格一點(diǎn)6. thinkphp6使用驗(yàn)證器 信息如何輸出到前端頁(yè)面7. 我在導(dǎo)入模板資源時(shí)遇到無(wú)法顯示的問(wèn)題,請(qǐng)老師解答下8. PHPExcel表格導(dǎo)入數(shù)據(jù)庫(kù)怎么導(dǎo)入9. javascript - 微信網(wǎng)頁(yè)開(kāi)發(fā)從菜單進(jìn)入頁(yè)面后,按返回鍵沒(méi)有關(guān)閉瀏覽器而是刷新當(dāng)前頁(yè)面,求解決?10. 預(yù)訂金和尾款分別支付

網(wǎng)公網(wǎng)安備