我的编程空间,编程开发者的网络收藏夹
学习永远不晚

oracle统计信息查看与收集的方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

oracle统计信息查看与收集的方法是什么

这篇文章主要讲解了“oracle统计信息查看与收集的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“oracle统计信息查看与收集的方法是什么”吧!


一、查看表统计信息

SQL> alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
SQL> select t.TABLE_NAME,t.NUM_ROWS,t.BLOCKS,t.LAST_ANALYZED from user_tables t where table_name='WOO';

备注:通过脚本查看统计信息,参考MOS:SCRIPT - Select to show Optimizer Statistics for CBO (Doc ID 31412.1)

二、查看表上的索引信息

select table_name,index_name,t.blevel,t.num_rows,t.leaf_blocks,t.last_analyzed 
  from user_indexes t 
  where table_name='DUMP_TABLE';
  
SQL> col table_name format a11
SQL> col index_name format a16
SQL> select table_name,index_name,t.blevel,t.num_rows,t.leaf_blocks,t.last_analyzed 
  2             from user_indexes t 
  3             where table_name='DUMP_TABLE';
TABLE_NAME  INDEX_NAME           BLEVEL   NUM_ROWS LEAF_BLOCKS LAST_ANAL
----------- ---------------- ---------- ---------- ----------- ---------
DUMP_TABLE  WORNUM_IND                0         10           1 18-MAR-20


  
三、检查当前统计信息收集策略

set linesize 140
col WINDOW_NAME format a17
col REPEAT_INTERVAL for a55
col DURATION for a15
select t1.window_name,t1.repeat_interval,t1.duration from 
 dba_scheduler_windows t1,dba_scheduler_wingroup_members t2  
 where t1.window_name=t2.window_name 
  and t2.window_group_name 
  in ('MAINTENANCE_WINDOW_GROUP','BSLN_MAINTAIN_STATS_SCHED');
  
  
SQL> set linesize 140
SQL> col WINDOW_NAME format a17
SQL> col REPEAT_INTERVAL for a55
SQL> col DURATION for a15
SQL> select t1.window_name,t1.repeat_interval,t1.duration from 
  2     dba_scheduler_windows t1,dba_scheduler_wingroup_members t2  
  3     where t1.window_name=t2.window_name 
  4             and t2.window_group_name 
  5             in ('MAINTENANCE_WINDOW_GROUP','BSLN_MAINTAIN_STATS_SCHED');
  
WINDOW_NAME       REPEAT_INTERVAL                                         DURATION
----------------- ------------------------------------------------------- ---------------
MONDAY_WINDOW     freq=daily;byday=MON;byhour=22;byminute=0; bysecond=0   +000 04:00:00
TUESDAY_WINDOW    freq=daily;byday=TUE;byhour=22;byminute=0; bysecond=0   +000 04:00:00
WEDNESDAY_WINDOW  freq=daily;byday=WED;byhour=22;byminute=0; bysecond=0   +000 04:00:00
THURSDAY_WINDOW   freq=daily;byday=THU;byhour=22;byminute=0; bysecond=0   +000 04:00:00
FRIDAY_WINDOW     freq=daily;byday=FRI;byhour=22;byminute=0; bysecond=0   +000 04:00:00
SATURDAY_WINDOW   freq=daily;byday=SAT;byhour=6;byminute=0; bysecond=0    +000 20:00:00
SUNDAY_WINDOW     freq=daily;byday=SUN;byhour=6;byminute=0; bysecond=0    +000 20:00:00
7 rows selected.


3.1. 关闭自动统计信息收集

BEGIN  
 DBMS_SCHEDULER.DISABLE(  
 name => '"SYS"."SATURDAY_WINDOW"',  
 force => TRUE);
END;
/

3.2 修改自动统计信息持续时间

BEGIN  
 DBMS_SCHEDULER.SET_ATTRIBUTE(  
 name => '"SYS"."SATURDAY_WINDOW"',  
 attribute => 'DURATION',  
 value => numtodsinterval(180,'minute'));
END; 
/

3.3 修改自动统计信息开始时间,每周六22点开始

BEGIN  
 DBMS_SCHEDULER.SET_ATTRIBUTE(  
 name => '"SYS"."SATURDAY_WINDOW"',  
 attribute => 'REPEAT_INTERVAL',  
 value => 'freq=daily;byday=SAT;byhour=22;byminute=0;bysecond=0 ');
END;
/

3.4 开启自动统计信息收集

BEGIN  
 DBMS_SCHEDULER.ENABLE(  
 name => '"SYS"."SATURDAY_WINDOW"');
END;
/

3.5 再次检查策略是否正确

set linesize 200
col REPEAT_INTERVAL for a60
col DURATION for a30
select t1.window_name,t1.repeat_interval,t1.duration 
 from dba_scheduler_windows t1,dba_scheduler_wingroup_members t2
  where t1.window_name=t2.window_name 
   and t2.window_group_name 
   in ('MAINTENANCE_WINDOW_GROUP','BSLN_MAINTAIN_STATS_SCHED');
WINDOW_NAME                    REPEAT_INTERVAL                                              DURATION
------------------------------ ------------------------------------------------------------ ------------------------------
MONDAY_WINDOW                  freq=daily;byday=MON;byhour=22;byminute=0; bysecond=0        +000 04:00:00
TUESDAY_WINDOW                 freq=daily;byday=TUE;byhour=22;byminute=0; bysecond=0        +000 04:00:00
WEDNESDAY_WINDOW               freq=daily;byday=WED;byhour=22;byminute=0; bysecond=0        +000 04:00:00
THURSDAY_WINDOW                freq=daily;byday=THU;byhour=22;byminute=0; bysecond=0        +000 04:00:00
FRIDAY_WINDOW                  freq=daily;byday=FRI;byhour=22;byminute=0; bysecond=0        +000 04:00:00
SATURDAY_WINDOW                freq=daily;byday=SAT;byhour=22;byminute=0;bysecond=0         +000 20:00:00
SUNDAY_WINDOW                  freq=daily;byday=SUN;byhour=6;byminute=0; bysecond=0         +000 20:00:00
7 rows selected.

四、手工收集统计信息

4.1 收集索引统计信息

exec dbms_stats.gather_index_stats(ownname => 'WOO',indname => 'WORNUM_IND',estimate_percent => '10',degree => '4');

4.2 收集表和索引统计信息 

exec dbms_stats.gather_table_stats(ownname => 'WOO',tabname => 'DUMP_TABLE',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE);

 

4.3 收集表的统计信息

exec dbms_stats.gather_table_stats(ownname => 'WOO',tabname => 'DUMP_TABLE',estimate_percent => 10,method_opt=> 'for all indexed columns');

 
 4.4 收集分区表统计信息

exec dbms_stats.gather_table_stats(ownname => 'WOO',tabname => 'DUMP_TABLE',partname => 'p_20190318',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE);

4.5 收集某个用户的统计信息

exec dbms_stats.gather_schema_stats(ownname=>'WOO',estimate_percent=>10,degree=>8,cascade=>true,granularity=>'ALL');

4.6 收集整个数据库的统计信息

exec dbms_stats.gather_database_stats(estimate_percent=>10,degree=>8,cascade=>true,granularity=>'ALL');

五、动态采样:

 对于新创建的表,当访问此表时,oracle会动态的收集这个表的相关信息,等到晚上10点,再将其收集到数据字典中。

SQL> set linesize 200
SQL> set autotrace traceonly
SQL> select  * from DUMP_TABLE;
10 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 1795212136
--------------------------------------------------------------------------------
| Id  | Operation         | Name       | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |            |    10 | 20390 |     3   (0)| 00:00:01 |
|   1 |  TABLE ACCESS FULL| DUMP_TABLE |    10 | 20390 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------------
Note
-----
   - dynamic sampling used for this statement (level=2)
Statistics
----------------------------------------------------------
          4  recursive calls
          0  db block gets
          9  consistent gets
          0  physical reads
          0  redo size
       1305  bytes sent via SQL*Net to client
        523  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
         10  rows processed

- dynamic sampling used for this statement (level=2) 表示动态采样,但是不记录数据字典,除非手动收集表的统计信息。

咱们通过user_tables查看结果也是一样的

SQL> set autotrace off;
SQL> select num_rows, blocks, last_analyzed from user_tables where table_name = 'DUMP_TABLE';
  NUM_ROWS     BLOCKS LAST_ANAL
---------- ---------- ---------
SQL>

六、统计信息收集完之后:

SQL> set linesize 200
SQL> set autotrace traceonly
SQL> select  * from DUMP_TABLE;
10 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 1795212136
--------------------------------------------------------------------------------
| Id  | Operation         | Name       | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |            |    10 |   470 |     3   (0)| 00:00:01 |
|   1 |  TABLE ACCESS FULL| DUMP_TABLE |    10 |   470 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------------
Statistics
----------------------------------------------------------
         33  recursive calls
          0  db block gets
         56  consistent gets
          0  physical reads
          0  redo size
       1305  bytes sent via SQL*Net to client
        523  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          6  sorts (memory)
          0  sorts (disk)
         10  rows processed
         
SQL> set autotrace off;
SQL> alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
SQL> select num_rows, blocks, last_analyzed from user_tables where table_name = 'DUMP_TABLE';
  NUM_ROWS     BLOCKS LAST_ANALYZED
---------- ---------- -------------------
        10          4 2020-03-18 17:06:16
SQL>

感谢各位的阅读,以上就是“oracle统计信息查看与收集的方法是什么”的内容了,经过本文的学习后,相信大家对oracle统计信息查看与收集的方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

oracle统计信息查看与收集的方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle统计信息收集的方法是什么

Oracle数据库中对表的统计信息可以通过以下方法进行收集:自动统计信息收集:Oracle数据库会自动收集表的统计信息,以便优化查询计划。可以通过设置参数 AUTOSTATS_TARGET 来控制自动收集统计信息的目标。手动收集统计信息:可
oracle统计信息收集的方法是什么
2024-04-09

Oracle Index函数与数据库的统计信息收集

Oracle Index 函数和数据库的统计信息收集是两个不同的概念,但它们之间存在一定的联系。Oracle Index 函数是用来创建索引、管理索引和优化查询性能的功能。索引是一种数据结构,可以加快数据库查询的速度。当数据库表中的数据量
Oracle Index函数与数据库的统计信息收集
2024-08-15

查看Linux系统版本信息的方法是什么

查看Linux系统版本信息的方法是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、查看Linux内核版本命令(两种方法):1、cat /proc/version2、u
2023-06-28

oracle查看字符集的方法是什么

Oracle数据库中查看字符集的方法有多种,以下是其中两种常用的方法:使用SQL查询NLS_DATABASE_PARAMETERS视图:SELECT parameter, valueFROM NLS_DATABASE_PARAMETERS
oracle查看字符集的方法是什么
2024-04-09

oracle字符集查看的方法是什么

要查看Oracle数据库的字符集,可以使用以下方法之一:使用SQL查询语句查看数据库的字符集:SELECT * FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER='NLS_CHARACTER
oracle字符集查看的方法是什么
2024-04-09

MySQL查看字符集的方法是什么

MySQL查看字符集的方法有两种:1. 使用SHOW VARIABLES语句:在MySQL命令行客户端中,输入以下命令:```SHOW VARIABLES LIKE 'character_set_%';```这将显示所有相关的字符集相关变量
2023-09-23

oracle查看序列的方法是什么

要查看Oracle数据库中的序列,可以使用以下SQL语句:SELECT sequence_name, last_numberFROM user_sequences;这将显示当前用户拥有的所有序列的名称和当前值。如果要查看其他用户的序列,
oracle查看序列的方法是什么
2024-05-13

oracle日志查看的方法是什么

要查看Oracle数据库的日志,可以使用以下几种方法:SQLPlus命令行工具:在命令行中使用SQLPlus连接到数据库实例,然后执行以下查询语句查看日志信息:SELECT * FROM v$log;这将显示当前数据库中所有的日志文件信息。
oracle日志查看的方法是什么
2024-04-09

查看linux系统内核信息的命令是什么

要查看Linux系统的内核信息,可以使用以下命令:```shelluname -a```这个命令会显示包括内核版本、主机名、操作系统和硬件架构等信息。
2023-08-29

oracle查看死锁的方法是什么

在Oracle数据库中,可以通过以下几种方法来查看死锁情况:使用V$LOCK视图:可以查询V$LOCK视图来查看数据库中的锁信息,包括锁类型、持有锁的会话ID、锁定的对象等。通过观察锁信息,可以判断是否存在死锁情况。使用DBA_BLOCK
oracle查看死锁的方法是什么
2024-04-09

域名信息查询的方法是什么

域名信息查询的方法有以下几种:1. WHOIS查询:WHOIS是一个查询域名注册信息的协议,可以通过WHOIS查询工具查询到域名的注册人、注册机构、注册时间、到期时间等信息。2. 域名注册商查询:通过域名注册商的查询工具,可以查询到域名的注
2023-06-08

编程热搜

目录