有无直方图,性能的差距

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

相关文章

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

Vue3 的 shallowRef 和 shallowReactive:优化性能

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

性能测试介绍

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