文章詳情頁
mysql優(yōu)化 - 關(guān)于mysql查詢時索引失效及掃描行數(shù)大于數(shù)據(jù)總行數(shù)的疑問。
瀏覽:177日期:2022-06-10 17:35:38
問題描述

對比前兩條語句,第二條沒有使用索引,我記得是掃描行數(shù)達(dá)到一定行數(shù)時會放棄使用索引,這個臨界值是多少呢?
全表掃描是顯示掃描行數(shù)是 70341 行,而數(shù)據(jù)總行數(shù)卻只有 57087 行?
select count(*) 使用了索引,但是也掃描了 70341 行,這個語句會產(chǎn)生性能問題嗎?
問題解答
回答1:CBO優(yōu)化機(jī)制的數(shù)據(jù)庫中,沒有明確的使用或不適用索引的臨界值,以執(zhí)行計劃中的COST最小為標(biāo)準(zhǔn),經(jīng)驗值是取表總行數(shù)小于5%的時候用索引比較合適。
我理解第二個語句使用的是表的統(tǒng)計數(shù)據(jù),如果表最近發(fā)生過比較大的變更,統(tǒng)計數(shù)據(jù)有沒有及時更新,會出現(xiàn)兩者偏差較大的情況。
count(*)使用了索引,說明update_at字段有NOT NULL的定義,相比較全表掃描,掃描索引的成本會更低一些。
相關(guān)文章:
1. javascript - sublime快鍵鍵問題2. javascript - immutable配合react提升性能?3. css - 寫頁面遇到個布局問題,求大佬們幫解答,在線等,急!~4. javascript - nodejs關(guān)于進(jìn)程間發(fā)送句柄的一點疑問5. Apache 已經(jīng)把網(wǎng)站根目錄的改為allow from all了,但是服務(wù)器還是不能訪問?6. 實現(xiàn)bing搜索工具urlAPI提交7. 配置Apache時,添加對PHP的支持時語法錯誤8. vue.js - Vue 如何像Angular.js watch 一樣監(jiān)聽數(shù)據(jù)變化9. javascript - 移動端上不能實現(xiàn)拖拽布局嗎?10. phpstudy8.1支持win11系統(tǒng)嗎?
排行榜

熱門標(biāo)簽
網(wǎng)公網(wǎng)安備