首页 > 其他分享 >2.基于成本的优化器

2.基于成本的优化器

时间:2023-04-01 15:47:35浏览次数:33  
标签:基于 01 14 00 t1 SQL c1 优化 成本

1.集的势

      定义:是指指定集合所包含的记录数,即是结果集的行数,cardinality表示对目标SQL的某个具体执行步骤的执行结果所包含的记录数的估算。如果是针对整个SQL,此时cardinality是指SQL最终结果所包含记录行数

2.可选择率

      定义:是指施加指定谓词条件后返回结果集的记录数占未施加任何条件的原始结果集的记录数的比率。

      总结:可选择率的值越大,就意味着返回结果集的cardinality的值就越大,所以估算出来的成本值也就会越大

2.1.测试CBO计算MGR的可选择率和该SQL返回结果集的cardinality

scott@ORCLPDB01 2023-04-01 14:56:12> exec dbms_stats.gather_table_stats(ownname=>'SCOTT',tabname=>'EMP',estimate_percent=>100,cascade=>true,method_opt=>'for all columns size 1',no_invalidate=>false);

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.03
scott@ORCLPDB01 2023-04-01 14:56:13> set autot trace;
scott@ORCLPDB01 2023-04-01 14:56:40> select * from emp where empno = 7902;

Elapsed: 00:00:00.01

Execution Plan
----------------------------------------------------------
Plan hash value: 2949544139

---------------------------------------------------------------------------------------------
| Id  | Operation		    | Name            | Rows  | Bytes | Cost (%CPU)| Time    |
---------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT	    |	          |	   1 |	  38 |	   1   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID| EMP         |	   1 |	  38 |	   1   (0)| 00:00:01 |
|*  2 |   INDEX UNIQUE SCAN	    | IDX_EMP_MGR |	   1 |	     |	   0   (0)| 00:00:01 |
---------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   2 - access("MGR"=7902)


Statistics
----------------------------------------------------------
	  1  recursive calls
	  0  db block gets
	  2  consistent gets
	  0  physical reads
	  0  redo size
	962  bytes sent via SQL*Net to client
	387  bytes received via SQL*Net from client
	  1  SQL*Net roundtrips to/from client
	  0  sorts (memory)
	  0  sorts (disk)
	  1  rows processed
scott@ORCLPDB01 2023-04-01 14:57:57> update emp set mgr = 7902;

14 rows updated.

Elapsed: 00:00:00.00
scott@ORCLPDB01 2023-04-01 14:58:10> commit;

Commit complete.

Elapsed: 00:00:00.01
scott@ORCLPDB01 2023-04-01 14:58:14> exec dbms_stats.gather_table_stats(ownname=>'SCOTT',tabname=>'EMP',estimate_percent=>100,cascade=>true,method_opt=>'for all columns size 1',no_invalidate=>false);

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.05
scott@ORCLPDB01 2023-04-01 14:59:19> select * from emp where mgr = 7902;

14 rows selected.

Elapsed: 00:00:00.00

Execution Plan
----------------------------------------------------------
Plan hash value: 351129165

---------------------------------------------------------------------------------------------------
| Id  | Operation			    | Name	  | Rows  | Bytes | Cost (%CPU)| Time	  |
---------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT		    |		  |    14 |   532 |	2   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID BATCHED| EMP	  |    14 |   532 |	2   (0)| 00:00:01 |
|*  2 |   INDEX RANGE SCAN		    | IDX_EMP_MGR |    14 |	  |	1   (0)| 00:00:01 |
---------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   2 - access("MGR"=7902)


Statistics
----------------------------------------------------------
	  1  recursive calls
	  0  db block gets
	  4  consistent gets
	  0  physical reads
	  0  redo size
       1713  bytes sent via SQL*Net to client
	396  bytes received via SQL*Net from client
	  2  SQL*Net roundtrips to/from client
	  0  sorts (memory)
	  0  sorts (disk)
	 14  rows processed
     
scott@ORCLPDB01 2023-04-01 15:12:49> exec dbms_stats.set_table_stats(ownname=>'SCOTT', tabname=>'EMP', numrows => 10000000, no_invalidate => false);

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.01
scott@ORCLPDB01 2023-04-01 15:12:56> exec dbms_stats.set_index_stats(ownname=>'SCOTT', indname => 'IDX_EMP_MGR', numlblks => 100000, no_invalidate => false);

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.01
scott@ORCLPDB01 2023-04-01 15:12:58> select * from emp where mgr = 7902;

14 rows selected.

Elapsed: 00:00:00.00

Execution Plan
----------------------------------------------------------
Plan hash value: 3956160932

--------------------------------------------------------------------------
| Id  | Operation	  | Name | Rows  | Bytes | Cost (%CPU)| Time	 |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |	 |    10M|   362M|   118  (98)| 00:00:01 |
|*  1 |  TABLE ACCESS FULL| EMP  |    10M|   362M|   118  (98)| 00:00:01 |
--------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   1 - filter("MGR"=7902)


Statistics
----------------------------------------------------------
	  6  recursive calls
	  0  db block gets
	 13  consistent gets
	  0  physical reads
	  0  redo size
       1620  bytes sent via SQL*Net to client
	400  bytes received via SQL*Net from client
	  2  SQL*Net roundtrips to/from client
	  0  sorts (memory)
	  0  sorts (disk)
	 14  rows processed

总结:

       1.CBO选择的执行计划可能会随着目标SQL中涉及的对象的统计信息的变化而变化。

       2.cardinality和selectivity的值会直接影响CBO对于执行步骤成本值得估算,进而影响CBO对于目标SQL执行计划得选择。

3.可传递性

3.1.简单谓词传递

t1.c1 = t2.c1 and t1.c1 = 10;
--谓词传递
t1.c1 = t2.c1 and t1.c1 = 10 and t2.c1 = 10

3.2.连接谓词传递

t1.c1 = t2.c1 and t2.c1 = t3.c1
--谓词传递
t1.c1 = t2.c1 and t2.c1 = t3.c1 and t1.c1 = t3.c1

3.3.外连接谓词传递

t1.c1 = t2.c1(+) and t1.c1 = 10
--谓词传递
t1.c1 = t2.c1(+) and t1.c1 = 10 and t2.c1(+) = 10

4.CBO的局限性

 4.1.CBO会默认目标SQL语句where条件中出现得各个列之间是独立的,没有关系

 4.2.CBO会假设所有的目标SQL都是单独执行的,并且互补干扰

 4.3.CBO对直方图统计信息有诸多限制

 4.4.CBO在解析夺标关联目标SQL时,可能会漏选正确的执行计划

标签:基于,01,14,00,t1,SQL,c1,优化,成本
From: https://www.cnblogs.com/yuanzijian/p/17278709.html

相关文章

  • 1.基于规则的优化器
    1.创建测试环境--建表createtableemp_tempasselect*fromemp;createindexidx_mgr_temponemp_temp(mgr);createindexidx_deptno_temponemp_temp(deptno);--查询数据库select*fromemp_tempwheremgr>100anddeptno>10;EMPNOENAMEJOB ......
  • 通过 OG 标签优化网站在社交媒体上的显示效果
    介绍OG标签是OpenGraphProtocol的缩写,是一种由Facebook所定义和推广的元数据协议,用于在社交媒体上显示网页的预览内容。OG标签允许网站管理员控制他们网站页面在Facebook、Twitter、LinkedIn等社交媒体上的展示形式,可以设置网页的标题、描述、图像、URL等元素......
  • 基于zynq的OV5640摄像头的sobel算子边缘检测
    最近鸽了挺久的,因为最近要做课设,再加上被这个工程的调试给难到了。在做该工程的时候,有一个良好的项目管理习惯会让开发的时候不会让人那么的高血压。特别要注意的是,异步FIFO的读写时钟的速率匹配问题,这个问题卡了我好久。1、sobel算子Sobel算法是像素图像边缘检测中最重要的......
  • 如何基于AI视觉识别技术实现明厨亮灶可视化监管?
    为保障食品安全,近年来各地市场监督管理局以云计算、大数据、人工智能为技术支撑,叠加视频监控技术,全力打造“互联网+明厨亮灶”智慧食安监管服务体系。实现对后厨的透明化、规范化、智能化管理。今天我们着重介绍下,如何基于AI视觉识别技术实现对餐饮服务单位可视化监管。SkeyeVSS综......
  • 基于Spring的AOP(注解方式)
    面向切面编程:基于Spring的AOP(注解方式)1-配置:pom文件:<packaging>jar</packaging><dependencies><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactI......
  • 基于凸集上投影(POCS)的聚类算法
    POCS:ProjectionsontoConvexSets。在数学中,凸集是指其中任意两点间的线段均在该集合内的集合。而投影则是将某个点映射到另一个空间中的某个子空间上的操作。给定一个凸集合和一个点,可以通过找到该点在该凸集合上的投影来进行操作。该投影是离该点最近的凸集内的点,可以通过最小......
  • 基于matlab的高精度信号峰值检测算法
    1.算法描述       峰值检验是示波表中数据采集方式之一,这种技术起源于存储深度不能满足捕获毛刺的需要。如果用模拟示波器去观察,只有当毛刺信号是重复性的并且和主信号同步时,才能看到毛刺信号。由于毛刺源于其他电路系统,所以这些毛刺只是偶尔发生,并且和主信号......
  • m基于强化学习的PID控制器simulink仿真,对比PI控制器和变结构PI控制器
    1.算法描述       PID控制器,即控制器的控制方式为P比例调整,I积分调整以及D微分调整三个部分构成,PID控制器是目前为止应用最为广泛的控制方式。PID控制器具有结构简单,性能稳定,参数设置简单等优势。PID控制器适用于各种控制对象无法进行测量获得系统参数的情况,其根据控制对......
  • m基于PID控制算法的四旋翼无人机飞行控制simulink仿真
    1.算法描述  无人机采用常见的四旋翼无人飞行器,如图1所示。           PID控制器,即控制器的控制方式为P比例调整,I积分调整以及D微分调整三个部分构成,PID控制器是目前为止应用最为广泛的控制方式。PID控制器具有结构简单,性能稳定,参数设置简单等优势。PID控制......
  • 关于IAM-基于aws-cli的方式将policy策略attach到role-以及需要的最小的权限-Policy策
    关于如何使用命令行创建policy,可以参考笔者的另一篇文章《关于IAM-基于aws-cli的方式创建Policy策略-以及需要的最小的权限-Policy策略》这里笔者主要讲,如何使用awscli方式的命令行将policy策略attach添加到指定的role当中,命令如下:aws--profile123iamattach-role-policy--......