EXPLAIN和SHOW TABLE STATUS LIKE里返回的rows为什么不准确
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这篇文章给大家介绍EXPLAIN和SHOW TABLE STATUS LIKE里返回的rows为什么不准确,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。"SHOW TABLE S
千家信息网最后更新 2025年01月31日EXPLAIN和SHOW TABLE STATUS LIKE里返回的rows为什么不准确
这篇文章给大家介绍EXPLAIN和SHOW TABLE STATUS LIKE里返回的rows为什么不准确,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
"SHOW TABLE STATUS LIKE 里返回的 rows 为什么不是准确的啊 ?"今天,我就抽个时间简单的说一下!
首先,我们根据字面意思来看,rows 代表的行数。准确的说是受影响的行数,或者说是扫描的行数!
从理论上来说,我实际查询扫描了多少行数,应该是准确的。但是这里显示不准确,MySQL 统计的不准确,是 MySQL 故意这样设计的吗?如果是,那为什么要这样设计?
显然,不准确的这件事,MySQL 是知道的。那么它这样设计一定是有原因的。
我们都知道,MySQL 有一个优化器,它会对你的 SQL 进行一些优化。优化器的原理就是在真正执行 SQL 之前来估算一些每种执行策略的代价,选择一种它认为最好的方案去执行!
由于,优化器是在真正执行前做出的判断,所以它不可能是准确的。优化器,只能根据索引的"区分度"来统计、估算要扫描的行数。
在这里,MySQL 为了操作数据更高效。利用数学知识,做了一个抽样统计。
抽样,就是 InnoDB 默认会选择 N 个数据页,统计这些页面上的不同值,得到一个平均值,然后乘以这个索引的页面数,就得到了这个索引的基数。
以上也就解释了为什么 EXPLAIN 和 SHOW TABLE STATUS LIKE 里返回的 rows 不准确!
关于EXPLAIN和SHOW TABLE STATUS LIKE里返回的rows为什么不准确就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
统计
索引
设计
内容
就是
数据
更多
知识
说是
页面
帮助
抽样
选择
不同
不错
代价
代表
兴趣
原因
原理
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
恒指软件开发
网络安全课工作总结
通付盾 中国网络安全50
抢手机小软件开发
软件开发合伙协议
数据库主要元素
网络安全是一网统管的保障
松江区手机软件开发公司
灵动互联网科技
40岁入行数据库
上海先进网络技术
长春盘古网络技术公司属于哪
郧西公司软件开发案例
张店瓷砖管理软件开发
打开修改数据库的工具
什么软件开发可以赚钱
软件开发是和程序员的区别
一网络安全法
软件开发最全文档
网络技术服务收入如何纳税
网络安全法的意义有什么
大港油田网络安全周试题
软件开发代码遵循的标准
共享电瓶车充电桩服务器
数据库上机五套考试题
青岛航天信息公司代理服务器端口
数字文化软件开发
你没有连接到安全服务器
达内软件开发教程
中国网络安全部队在哪里