为准确生成执行计划更新统计信息-analyze与dbms_stats
如果我们想让CBO利用合理利用数据的统计信息,正确判断执行任何SQL查询时的最快途径,需要及时的使用analyze命令或者dbms_stats重新统计数据的统计信息.
例如索引跳跃式扫描(INDEX SKIP SCAN)例子中,如果不对表EMPLOYEE 及索引收集一下统计信息,就不是INDEX SKIP SCAN策略了。
在oracle 8i以前,主要是用ANALYZE命令。在ORACLE 8I以后,又引入了DBMS_STATS存储包来进行分析。幸运的是从ORACLE 10G以后,分析工作变成自动的了,这减轻的DBA的负担
分析统计信息
analyze table 一般可以指定分析: 表,所有字段,所有索引字段,所有索引。 若不指定则全部都分析。
---table统计信息
analyze table EMP compute statistics for table; ---column统计信息
analyze table EMP compute statistics for all columns; ---索引统计信息
analyze table EMP compute statistics for all indexes; ---索引列统计信息
analyze table EMP compute statistics for all indexed columns; ---效果等于 analyze table tablename compute statistics for table for all indexes for all columns
analyze table tablename compute statistics
查看统计信息
for table的统计信息存在于视图:user_tables 、all_tables、dba_tables
for all indexes的统计信息存在于视图: user_indexes 、all_indexes、dba_indexes
for all columns的统计信息存在于试图:user_tab_columns、all_tab_columns、dba_tab_columns
SCOTT@PDBORCL> analyze table EMP compute statistics for table;
表已分析。 SCOTT@PDBORCL> analyze table EMP compute statistics for all columns;
表已分析。 SCOTT@PDBORCL> analyze table EMP compute statistics for all indexes;
表已分析。 SCOTT@PDBORCL> select table_name,num_rows from user_tables where table_name = 'EMP';
TABLE_NAME NUM_ROWS
----------- -----------
EMP 14 SCOTT@PDBORCL> select index_name,uniqueness from user_indexes where table_name = 'EMP';
INDEX_NAME UNIQUENES
-------- ---------
PK_EMP UNIQUE SCOTT@PDBORCL> select column_name,data_type from user_tab_columns where table_name = 'EMP' ; COLUMN_NAME DATA_TYPE
-------------------------
EMPNO NUMBER
ENAME VARCHAR2
JOB VARCHAR2
MGR NUMBER
HIREDATE DATE
SAL NUMBER
COMM NUMBER
DEPTNO NUMBER 已选择 8 行。 SCOTT@PDBORCL> ^A
删除统计信息
会删除emp所有的statistics。
analyze table emp delete statistics
删除只是某些列变为空,如emp表的行数为空了
SCOTT@PDBORCL> analyze table emp compute statistics; 表已分析。 SCOTT@PDBORCL> select table_name,num_rows from user_tables where table_name = 'EMP'; TABLE_NAME NUM_ROWS
-------- ----------
EMP 14 SCOTT@PDBORCL> analyze table emp delete statistics; 表已分析。 SCOTT@PDBORCL> select table_name,num_rows from user_tables where table_name = 'EMP'; TABLE_NAME NUM_ROWS
-------- ----------
EMP SCOTT@PDBORCL>
dbms_stats
dbms_stats能良好地估计统计数据(尤其是针对较大的分区表),并能获得更好的统计结果,最终制定出速度更快的SQL执行计划。
语法:
dbms_stats.gather_table_stats (
ownname varchar2,
tabname varchar2,
partname varchar2,
estimate_percent number,
block_sample boolean,
method_opt varchar2,
degree number,
granularity varchar2,
cascade boolean,
stattab varchar2,
statid varchar2,
statown varchar2,
no_invalidate boolean,
force boolean
);
dbms_stats.delete_table_stats 用于删除统计信息。
例子:
------删除统计信息SCOTT@PDBORCL> exec dbms_stats.delete_table_stats (ownname => 'scott',tabname => 'emp'); PL/SQL 过程已成功完成。
----查询统计信息
SCOTT@PDBORCL> select table_name,num_rows from user_tables where table_name = 'EMP'; TABLE_NAME NUM_ROWS
-------- ----------
EMP ---获取统计信息SCOTT@PDBORCL> exec dbms_stats.gather_table_stats (ownname => 'scott',tabname => 'emp'); PL/SQL 过程已成功完成。
---重新查新统计信息
SCOTT@PDBORCL> select table_name,num_rows from user_tables where table_name = 'EMP'; TABLE_NAME NUM_ROWS
-------- ----------
EMP 14 SCOTT@PDBORCL>
参考:
http://docs.oracle.com/database/121/TGSQL/tgsql_stats.htm#TGSQL389
为准确生成执行计划更新统计信息-analyze与dbms_stats的更多相关文章
- SQL Server 执行计划利用统计信息对数据行的预估原理二(为什么复合索引列顺序会影响到执行计划对数据行的预估)
本文出处:http://www.cnblogs.com/wy123/p/6008477.html 关于统计信息对数据行数做预估,之前写过对非相关列(单独或者单独的索引列)进行预估时候的算法,参考这里. ...
- Oracle执行计划与统计信息的一些总结
[日期:2011-08-05]来源:Linux社区 作者:wangshengfeng1986211[字体:大 中 小] 2010-07-01 15:03 1.SET AUTOTRACE ON EXP ...
- sqlplus中显示sql执行计划和统计信息
31 ,32 , 33 ,34 keywords : oracle storage structure 最详细讲解: 1:doc 1 logical storage structure 2 ...
- SQL Server 执行计划利用统计信息对数据行的预估原理以及SQL Server 2014中预估策略的改变
前提 本文仅讨论SQL Server查询时, 对于非复合统计信息,也即每个字段的统计信息只包含当前列的数据分布的情况下, 在用多个字段进行组合查询的时候,如何根据统计信息去预估行数的. 利用不同字段 ...
- 第十二章——SQLServer统计信息(1)——创建和更新统计信息
原文:第十二章--SQLServer统计信息(1)--创建和更新统计信息 简介: 查询的统计信息: 目前为止,已经介绍了选择索引.维护索引.如果有合适的索引并实时更新统计信息,那么优化器会选择有用的索 ...
- SQLServer 创建dtsx包更新统计信息(示例)
http://blog.csdn.net/kk185800961/article/details/43816177(转载) 1 . 打开Microsoft Visual Studio 创建 integ ...
- SQL Server 更新统计信息出现严重错误,应放弃任何可能产生的结果
一台SQL Server 2008 R2版本(具体版本如下所示)的数据库,最近几天更新统计信息的作业出错,错误如下所示: Microsoft SQL Server 2008 R2 (SP2) - ...
- SQL2008R2的 遍历所有表更新统计信息 和 索引重建
[2.以下是更新统计信息] DECLARE UpdateStatisticsTables CURSOR READ_ONLY FOR SELECT sst.name, Schema_name(sst.s ...
- PG 更新统计信息
http://blog.chinaunix.net/uid-24774106-id-3802225.html 一.vacuum的效果: 1.1释放,再利用 更新/删除的行所占据的磁盘空间. 第一点的原 ...
随机推荐
- nodejs ffi(DLL)
npm install ffi Error: The specified module could not be found. npm rebuild var ffi = require('ffi') ...
- [web 前端] web本地存储(localStorage、sessionStorage)
cp from : https://blog.csdn.net/mjzhang1993/article/details/70820868 web 本地存储 (localStorage.sessionS ...
- [转]MySQL单列索引和组合索引的区别介绍
FROM : http://database.ctocio.com.cn/353/11664853.shtml MySQL单列索引是我们使用MySQL数据库中经常会见到的,MySQL单列索引和组合索引 ...
- 使用Bootstrap后,关于IE与Chrome显示字体的问题
在做日志系统时,使用了Bootstrap,然后通过浏览器查看的页面效果如下 对比可以看到,同样的字体,IE显示的圆润些,而Chrome字体则丑很多.因为Chrome默认用宋体 在http://v3.b ...
- ios开发第三方库--cocoapods安装
1. ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)&quo ...
- LeetCode 114| Flatten Binary Tree to Linked List(二叉树转化成链表)
题目 给定一个二叉树,原地将它展开为链表. 例如,给定二叉树 1 / \ 2 5 / \ \ 3 4 6 将其展开为: 1 \ 2 \ 3 \ 4 \ 5 \ 6 解析 通过递归实现:可以用先序遍历, ...
- 重启Windows的PowerShell
这么简单的一个命令都单独写一篇blog, 是不是太无耻了? 好吧, 谁让咱不会呢. 学会了就来一篇. 呵呵. Restart-Computer 来源 ================ http:/ ...
- Centos7 Mysql 双机热备实现数据库高可用
mysql双主热备,也称主主互备,目的是mysql数据库高可用,只支持双机,原因是mysql的复制是一主多从,但一个从服务器只能有一个主服务器. 双机热备的条件是双机mysql版本必须一致. 服务器分 ...
- mybatis @Select注解中如何拼写动态sql
@Mapper public interface DemandCommentMapper extends BaseMapper<DemandComment>{ @Select(" ...
- nginx配置目录列表访问权限
我们知道apache httpd默认情况下会显示访问目录的文件列表,但是nginx访问时如果目录下面没有默认首页,那么会返回403 Forbidden的错误,表示没有权限访问,比如根目录就是nginx ...