oracle 几个字段中某个字段大于0其他字段不再进行统计?_如何深入理解MySQL 8.0直方图?...

fef785acb2774029996de96e15ff464c.png

MySQL8.0 新功能直方图,继承于Oracle ,MairaDB的实现方式。 那下面从mysql角度认识下,直方图是什么。先看下官方直方图的实现方式。

1fcb7f5f17324370bbb236b481f19793.png

从上图上可以看到原来是ANALYZE命令。先了解一下MySQL里 ANALYZE命令到底有什么用。

ANALYZE

在MySQL里提交一条查询SQL语句时,优化器会选在一个最优的执行方案,并用最小的代价去执行语句。在数据库里面,扫描行数是影响执行代价的因素之一。扫描的行数越少,意味着资源资源越少,扫描行数是怎么判断,是通过索引的基数来得到值和row。

mysql>SHOW INDEX FROM table_name

622b64a26b6f63b4f5d80b7cf76707ee.png

执行计划里出现的Cardinality(基数)字段,是非常重要的: 基数计算是采样统计,如果把整张表取出来一行行统计,虽然可以得到精确的结果,但是代价太高。采样统计的时候InnoDB 默认会选择 N 个数据页,统计这些页面上的不同值,得到一个平均值,然后乘以这个索引的页面数,就得到了这个索引的基数。而数据表是会持续更新的,索引统计信息也不会固定不变。所以,当变更的数据行数超过 1/M 的时候,会自动触发重新做一次索引统计。

1995c2ce2dcf1ba63fbe52fb91706a89.png

基数很容易不准,除了基数优化器还要判断,执行这个语句本身要扫描多少rows 预计扫描行数.

因为统计信息不对,cardinality大大少于数据的实际散列程度,那么索引就有可能失效。

下面看看基数变化的情况: 1.第一次创建表导入数

ebcbfed1443b37d051a7d463c6d5d393.png

2.第二次把表drop掉,导入数据

e6947829387df706d006ba64834159da.png

在这种情况下就会使用analyze table 命令2次

b956d8e10bfea870d436159494ab440d.png

上面是2次,ANALYZE TABLE命令进行修复索引。在不停的浮动。 分析表通过对每个索引树执行随机潜水并相应地更新索引基数估计值来确定索引基数,所以这个值也不是100%准确。

ANALYZE TABLE的作用:

  • 统计索引分布信息。
  • 对于 MyISAM 表,相当于执行了一次 myisamchk --analyze
  • 支持 InnoDB.NDB.MyISAM 等存储引擎,但不支持视图(view)
  • 执行时,会对表加上读锁(read lock)
  • 该操作会记录binlog,可以在analyze和table之间添加关键字local取消写入

ANALYZE TABLE风险:

  • analyze table的需要扫描的page代价粗略估算公式:sample_pages * 索引数 * 表分区数。
  • 因此,索引数量较多,或者表分区数量较多时,可能会比较费时,要评估代价,并默认只在负载低谷时执行。
  • 如果某个表上当前有慢SQL,此时执行analyze table,则该表后续的查询均会处于waiting for table flush的状态,严重的话会影响业务,因此执行前必须先检查有无慢查询。
直方图

通过ANALYZE操作了解到,在数据库中查询优化所需的指标抽取方式。有时候,查询优化器会走不到最优的执行计划,导致花费了更多不必要的时间。直方图就是解决这样的问题.

直方图能近似获得一列的数据分布情况,从而让数据库知道它含有哪些数据。将数据分到了一系列的buckets中去。MySQL会自动将数据划到不同的buckets中,也会自动决定创建哪种类型的直方图。

1)从代码实现中,MySQL支持了两种:等宽直方图(singleton).等高直方图(equi-height)。

c16b13d23e478a650e1cb408ab030340.png

2)两个直方图区别在于equi-height 多了 下限和上限的指标。

9f7afc501cd36e7801d10c712715708a.png

3)选择直方图判断逻辑是:如果指定的桶数大于或等于桶数 对于不同的值,创建一个单例直方图。否则创建一个等高直方图。

aa668fc53d57b7e95bf4a134ac7d1991.png

...

本文接下来还有:

  1. 直方图命令
  2. 测试
  3. 总结

完整内容,请访问墨天轮平台【原文】进行查看~

425868817114fdb3aeb4386fa3cae357.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/507167.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Apache java文件比对,Java Apache Commons的字符串比较

1、使用Apache Commons的equals()实现字符串比较StringUtils类的equals()方法是String类方法equals()的增强版,它会处理null值:assertThat(StringUtils.equals(null, null)).isTrue();assertThat(StringUtils.equals(null, "equals method")).i…

godaddy修改php版本,Godaddy美国主机Plesk面板修改PHP版本教程

由于不同的需求,我们站长朋友们建站所用的网站程序也不尽相同,有PHP、ASP和ASP.NET等。Godaddy美国主机作为全球最大域名主机商,当之无愧成为站长使用最多的主机。不少朋友应该都知道不同的网站程序对于PHP和ASP的版本要求又不一样&#xff0…

mysql数据结构_mysql的底层数据结构

一.数据结构1. 二叉树特点:左侧子节点比父节点小,右侧子节点比父节点大(对于同一个父节点下的两个子节点)缺点:对于一直递增得数据不能存在该数据结构中,会变成链表,不能降低树的高度图 1-1图1-22. 红黑树特…

python 隐含波动率_【BSM模型】用实际市场数据计算隐含波动率并验证波动率微笑...

在Black-Scholes期权定价模型中,不能直接观察到的参数只有股票价格的波动率。波动率可以由历史数据进行估计,这是历史波动率。隐含波动率也是交易员非常关心的,隐含波动率是期权的市场价格中所包含的波动率,即由期权价格和期权定价…

php获得指定目录文件,PHP遍历指定文件夹获取路径及大小(包含子文件夹)

PHP获取指定文件夹下(包含子文件夹)所有文件路径 及 大小代码如下:// 获取指定文件夹 所有文件及大小 (包含子文件夹) By 【简爱】function JA_files2arr($dirpath){if($dirpath[strlen($dirpath)-1]!"/"){$dirpath."/";} //static $result_arr…

winform判断线程有没有完成_并发编程系列1:线程池的架构实现、大小配置、及四种线程池使用...

△ 公众号回复关键词“架构” 即可领取《1500BAT架构及面试专题合集》本篇为线程池系列文章之一,不经常使用线程池的童鞋,还有对几种线程的使用不甚了解的童鞋,可以读一下此文,并关注后续线程池相关文章连载。 本篇内容大纲&#…

python枚举是什么意思,什么是枚举python

枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表示某些特定的有限集合,例如星期、月份、状态等。Python 的原生类型(Built-in types)里并没有专门的枚举类型,但是我们可以通过很多方法来实现它,例如字典、类等&#x…

php 10060,远程连接mysql 10060错误

远程连接mysql 10060错误Could not connect: Cant connect to MySQL server on ***.***.***.*** (10060)代码是$con mysql_connect("***.***.***.***","user","Password");if (!$con){die(Could not connect: . mysql_error());}用户名和密码正…

python包含多个元组的元组_Python数据结构(元组,列表,字典)

Python内置了 几种数据结构,元组,列表 字典1.元组元组可以由不同的元素组成,所有元素通过圆括号( )包含起来,并通过逗号","隔开.如变量名 (元素1,元素2,...),如果a 1,3,56,abc,aoe,也默认a是元组每个元素也可以是不同的数据类型,字符串,数字,元组,列表,字典元组的元…

vscode 导入python库_vscode 如何导入python库

vscode 如何导入python库首先,我们要知道,VScode和本地运行的并不是同一个python,反正我的是这样,所以导致了在本地下载好库后,在VScode运行时还是报错。那么如何在VScode中导入python库呢?1.已经在vscode中…

docker部署php站点,docker部署php

## **Docker部署php**操作系统:Ubuntu16.04 / Ubuntu18.04~~~//查看可用的php版本$ docker search php//这里安装php7.1版$ docker pull php:7.1-fpm//启动挂载$ docker run -p 9000:9000 -d --name myphp-fpm -v /docker/www:/usr/share/nginx/www php:7.1-fpm//这…

python怎么退出调试模式_python – 在验尸调试时如何退出ipdb?

我喜欢使用以下方式检查Python脚本中的错误:$python3 -m pdb my_script.py这会让我进入一个pdb提示,从那里我可以继续执行,当它遇到错误,我可以检查变量,然后q退出脚本执行以回到我的shell.我尝试与iPython调试器模块相同,因为它更加丰富多彩:$python3 -…

oracle捕捉所有异常,如何捕获和处理特定的Oracle异常?

你有两个选择:直接通过编号参考例外:BEGINEXECUTE IMMEDIATE CREATE SEQUENCE S_TEST START WITH 1 INCREMENT BY 1;EXCEPTIONWHEN OTHERS THENIF SQLCODE -955 THENNULL; -- suppresses ORA-00955 exceptionELSERAISE;END IF;END;其他选项是使用EXCEPT…

拖拽批量上传图片如何保证 顺序_图片压缩神器和图片分割工具,美工设计和运营终于得救了...

想要快速互联网干货技巧?请(置顶)星标我们好不容易写好文案,设计好长图海报,上传到微信公众号,竟然提示上传图片体积不得超过5M,怎么办?怎么办?不得已,只好又返回Ps里降低…

php将word转txt,PHP如何将将word文件转为pdf

PHP将word文件转为pdf的方法:首先修改【php.ini】,并重启环境;然后安装微软office套件;最后配置office组件服务即可。PHP将word文件转为pdf的方法:1、修改php.ini添加:extensionphp_com_dotnet.dll去除注释…

redis一般缓存什么样数据_SpringBoot+Redis轻松实现数据缓存

1.为什么需要缓存为什么需要缓存,我相信搞开发的都能回答出来,无非就是为了降低数据库压力,节约资源,提升系统性能。而事实上也确实是,归根结底就是降压,高并发,高性能。不过,大厂里…

python里面的import provide_Python importorror:没有名为wmi的模块

我按照说明在这里下载了用于Python的WMI当我试图运行代码时import wmic wmi.WMI ()for s in c.Win32_Service (StartMode"Auto", State"Stopped"):if raw_input ("Restart %s? " % s.Caption).upper () "Y":s.StartService ()我收到…

php 微信消息解密,thinkphp微信开发(消息加密解密)

使用thinkphp官方的WeChat包,使用不同模式可以成功,但是安全模式就是不行,现将分析解决结果做下记录。分析问题:解密微信服务器消息老是不成功,下载下微信公众平台官方给出的解密文件和WechatCrypt.class.php进行比对发…

模型预测控制_模型预测控制(MPC)算法之一MAC算法

引言随着自动驾驶技术以及机器人控制技术的不断发展及逐渐火热,模型预测控制(MPC)算法作为一种先进的控制算法,其应用范围与领域得到了进一步拓展与延伸。目前提出的模型预测控制算法主要有基于非参数模型的模型算法控制(MAC)和动态矩阵控制(DMC)&#x…

基于dde的vb和matlab,基于VB和DDE技术的组态王通信协议转换

组态王是一种通用的工业监控上位机软件,它界面友好、易学易用、即便是不懂编程的工程人员也能在短时时间内开发出界面精美,符合行业标准且高效的上位机监控程序,因此深受工程师们的喜爱,然而组态王软件的上下位机通信协议是固定的切不可改变,这就给一些使用“自拟定协议”和“非…