有无直方图,性能的差距

2024-09-07 12:38
文章标签 性能 直方图 差距 有无

本文主要是介绍有无直方图,性能的差距,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#################################
###有无直方图,性能的差距###
#################################
实验的环境在redhat平台下的11gr2单实例环境
1、在自己定义的用户下创建表及索引
CREATE TABLE customers AS SELECT * FROM sh.customers;
CREATE INDEX customers_country_ix ON customers(country_id);
2、收集表的收集信息
BEGIN
   SYS.DBMS_STATS.gather_table_stats (ownname      =>'TRSEN',
                                      tabname      => 'CUSTOMERS');
END;
/

3、查看一下统计信息(列的密度、列的空值、列的不同值)
SQL> SELECT density, num_nulls, num_distinct
  2    FROM user_tab_col_statistics
  3   WHERE table_name = 'CUSTOMERS' AND column_name = 'COUNTRY_ID';

   DENSITY  NUM_NULLS NUM_DISTINCT
---------- ---------- ------------
.052631579          0           19
4、执行两条语句
SQL> SELECT MAX (cust_income_level)
  2    FROM customers
  3   WHERE country_id = 52787;
Execution Plan
----------------------------------------------------------
Plan hash value: 296924608
--------------------------------------------------------------------------------
| Id  | Operation          | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |           |     1 |    26 |   406   (1)| 00:00:05 |
|   1 |  SORT AGGREGATE    |           |     1 |    26 |            |          |
|*  2 |   TABLE ACCESS FULL| CUSTOMERS |  2921 | 75946 |   406   (1)| 00:00:05 |
--------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   2 - filter("COUNTRY_ID"=52787)

SQL> SELECT MAX (cust_income_level)
  2    FROM customers
  3   WHERE country_id = 52790;
Execution Plan
----------------------------------------------------------
Plan hash value: 296924608
--------------------------------------------------------------------------------
| Id  | Operation          | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |           |     1 |    26 |   406   (1)| 00:00:05 |
|   1 |  SORT AGGREGATE    |           |     1 |    26 |            |          |
|*  2 |   TABLE ACCESS FULL| CUSTOMERS |  2921 | 75946 |   406   (1)| 00:00:05 |
--------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   2 - filter("COUNTRY_ID"=52790)
4、收集索引列直方图信息
     SYS.DBMS_STATS.gather_table_stats (ownname         => 'TRSEN',
  3                                        tabname         => 'CUSTOMERS',
  4                                        method_opt      => 'FOR ALL INDEXED COLUMNS'
  5                                       );
  6  END;
  7  /
PL/SQL procedure successfully completed.
5、查看统计信息,发现列的密度发生改变了
SQL> SELECT density, num_nulls, num_distinct
  2    FROM user_tab_col_statistics
  3   WHERE table_name = 'CUSTOMERS' AND column_name = 'COUNTRY_ID';
   DENSITY  NUM_NULLS NUM_DISTINCT
---------- ---------- ------------
9.1437E-06          0           19
6、此时查询查看执行计划
SQL> SELECT MAX (cust_income_level)
  2    FROM customers
  3   WHERE country_id = 52787;
Execution Plan
----------------------------------------------------------
Plan hash value: 479268801
-----------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name                 | Rows  | Bytes | Co
st (%CPU)| Time     |
-----------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |                      |     1 |    26 |23   (0)| 00:00:01 |
|   1 |  SORT AGGREGATE              |                      |     1 |    26 |      |          |
|   2 |   TABLE ACCESS BY INDEX ROWID| CUSTOMERS            |   102 |  2652 |23   (0)| 00:00:01 |
|*  3 |    INDEX RANGE SCAN          | CUSTOMERS_COUNTRY_IX |   102 |       |1   (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   3 - access("COUNTRY_ID"=52787)

SQL> SELECT MAX (cust_income_level)
  2    FROM customers
  3   WHERE country_id = 52790;
--------------------------------------------------------------------------------
| Id  | Operation          | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |           |     1 |    26 |   406   (1)| 00:00:05 |
|   1 |  SORT AGGREGATE    |           |     1 |    26 |            |          |
|*  2 |   TABLE ACCESS FULL| CUSTOMERS | 18230 |   462K|   406   (1)| 00:00:05 |
--------------------------------------------------------------------------------
   2 - filter("COUNTRY_ID"=52790)

7、强制走索引查看执行计划
SQL> SELECT MAX (cust_income_level)
  2    FROM customers
  3   WHERE country_id = 52790;
Execution Plan
----------------------------------------------------------
Plan hash value: 296924608
--------------------------------------------------------------------------------
| Id  | Operation          | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT   |           |     1 |    26 |   406   (1)| 00:00:05 |
|   1 |  SORT AGGREGATE    |           |     1 |    26 |            |          |
|*  2 |   TABLE ACCESS FULL| CUSTOMERS | 18230 |   462K|   406   (1)| 00:00:05 |
--------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   2 - filter("COUNTRY_ID"=52790)

SQL> SELECT /*+ INDEX(customers) */
  2         MAX (cust_income_level)
  3    FROM customers
  4   WHERE country_id = 52790;
Execution Plan
----------------------------------------------------------
Plan hash value: 479268801
-----------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name                 | Rows  | Bytes | Cost (%CPU)| Time     |
----------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |                      |     1 |    26 |  3
872   (1)| 00:00:47 |
|   1 |  SORT AGGREGATE              |                      |     1 |    26 |        |          |
|   2 |   TABLE ACCESS BY INDEX ROWID| CUSTOMERS            | 18230 |   462K|  3872   (1)| 00:00:47 |
|*  3 |    INDEX RANGE SCAN          | CUSTOMERS_COUNTRY_IX | 18230 |       |41   (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   3 - access("COUNTRY_ID"=52790)
SQL> SELECT /*+ INDEX(customers) */
  2         MAX (cust_income_level)
  3    FROM customers
  4   WHERE country_id = 52787;
Execution Plan
----------------------------------------------------------
Plan hash value: 479268801
-----------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name                 | Rows  | Bytes | Co
st (%CPU)| Time     |
-----------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |                      |     1 |    26 |23   (0)| 00:00:01 |
|   1 |  SORT AGGREGATE              |                      |     1 |    26 |        |          |
|   2 |   TABLE ACCESS BY INDEX ROWID| CUSTOMERS            |   102 |  2652 |23   (0)| 00:00:01 |
|*  3 |    INDEX RANGE SCAN          | CUSTOMERS_COUNTRY_IX |   102 |       |1   (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   3 - access("COUNTRY_ID"=52787)
8、这张表的数据分布及实验结果分析
 select country_id,count(country_id) as total from customers group by country_id order by  total;
 
从这张统计表可以看出一些信息有19个country_id值,有30%左右的数据在52790列上,如果我们要搜索一个特定的country_id=52787,优化器也会选择全表扫描

9、清除收集的直方图信息语句
BEGIN
   SYS.DBMS_STATS.gather_table_stats ('TRSEN','CUSTOMERS',method_opt=>'FOR ALL INDEXED COLUMNS size 1');
END;
/
10、针对consistent gets分析结果图
 
实验分析:列的直方图创建,使得oracle能够在其他值不具备选择性的列中识别出那些有选择性的值。优化能够为有选择性的值选择使用索引,为没有选择性的列值选择全表扫描。即便强制没有选择性的列走索引,但其性能会更差。

这篇关于有无直方图,性能的差距的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145081

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

黑神话,XSKY 星飞全闪单卷性能突破310万

当下,云计算仍然是企业主要的基础架构,随着关键业务的逐步虚拟化和云化,对于块存储的性能要求也日益提高。企业对于低延迟、高稳定性的存储解决方案的需求日益迫切。为了满足这些日益增长的 IO 密集型应用场景,众多云服务提供商正在不断推陈出新,推出具有更低时延和更高 IOPS 性能的云硬盘产品。 8 月 22 日 2024 DTCC 大会上(第十五届中国数据库技术大会),XSKY星辰天合正式公布了基于星

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

PR曲线——一个更敏感的性能评估工具

在不均衡数据集的情况下,精确率-召回率(Precision-Recall, PR)曲线是一种非常有用的工具,因为它提供了比传统的ROC曲线更准确的性能评估。以下是PR曲线在不均衡数据情况下的一些作用: 关注少数类:在不均衡数据集中,少数类的样本数量远少于多数类。PR曲线通过关注少数类(通常是正类)的性能来弥补这一点,因为它直接评估模型在识别正类方面的能力。 精确率与召回率的平衡:精确率(Pr

SQL2005 性能监视器计数器错误解决方法

【系统环境】 windows 2003 +sql2005 【问题状况】 用户在不正当删除SQL2005后会造成SQL2005 性能监视器计数器错误,如下图 【解决办法】 1、在 “开始” --> “运行”中输入 regedit,开启注册表编辑器,定位到 [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVer

Linux性能分析工具合集

Linux性能分析工具合集 工具合集主要包含以下各种工具,对于了解Linux系统结构、网络结构、内核层次具有一定的帮助。 Linux Performance Observability ToolsLinux Static Performance ToolsLinux Performance Benchmark ToolsLinux Performance Tuning ToolsLinux

Linux的系统性能监测参数获取方法介绍

目前的工程需要简单的监测一下Linux系统的:CPU负载、内存消耗情况、几个指定目录的磁盘空间、磁盘I/O、swap的情况还有就是网络流量。   Linux下的性能检测工具其实都有很多。   mrtg(http://people.ee.ethz.ch/~oetiker/webtools/mrtg/)就是一个很不错的选择。不过用mrtg就要装sysstat、apache、snmp、pe

性能测试工具 wrk,ab,locust,Jmeter 压测结果比较

前言 在开发服务端软件时,经常需要进行性能测试,一般我采用手写性能测试代码的方式进行测试,那有什么现成的好的性能测试工具吗? 性能测试工具 wrk,ab,locust,Jmeter 压测结果比较 详见: 性能测试工具 wrk,ab,locust,Jmeter 压测结果比较 Jmeter性能测试 入门