文章详情页
mysql优化 - 关于mysql查询时索引失效及扫描行数大于数据总行数的疑问。
浏览:196日期:2022-06-10 17:35:38
问题描述

对比前两条语句,第二条没有使用索引,我记得是扫描行数达到一定行数时会放弃使用索引,这个临界值是多少呢?
全表扫描是显示扫描行数是 70341 行,而数据总行数却只有 57087 行?
select count(*) 使用了索引,但是也扫描了 70341 行,这个语句会产生性能问题吗?
问题解答
回答1:CBO优化机制的数据库中,没有明确的使用或不适用索引的临界值,以执行计划中的COST最小为标准,经验值是取表总行数小于5%的时候用索引比较合适。
我理解第二个语句使用的是表的统计数据,如果表最近发生过比较大的变更,统计数据有没有及时更新,会出现两者偏差较大的情况。
count(*)使用了索引,说明update_at字段有NOT NULL的定义,相比较全表扫描,扫描索引的成本会更低一些。
相关文章:
1. 系统重装后,恢复mysql5.5?2. Java中main方法里面的参数一定要是String []args吗?3. docker绑定了nginx端口 外部访问不到4. javascript - node.js中stat() access() open() readFile()都能判断文件是否存在?5. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路6. font-family - 我引入CSS3自定义字体没有效果?7. mysql - sql 左连接结果union右连接结果,导致重复性计算怎么解决?8. css3 - CSS优先级问题9. css - 如何讓圖片像雲一樣的行為?10. android - 微信的@功能如何实现的?
排行榜

网公网安备