`
helloyesyes
  • 浏览: 1306602 次
  • 性别: Icon_minigender_2
  • 来自: 武汉
文章分类
社区版块
存档分类
最新评论

Oracle 判断 并 手动收集 统计信息 脚本

阅读更多

. 说明

在之前的blog

Oracle Statistic 统计信息 小结

http://blog.csdn.net/tianlesoftware/archive/2009/10/15/4668723.aspx

里对统计信息的收集有说明, Oracle Automatic Statistics Gathering 是通过Scheduler 来实现收集和维护的。 Job 名称是GATHER_STATS_JOB, Job收集数据库所有对象的2种统计信息:

1Missing statistics(统计信息缺失)

2Stale statistics(统计信息陈旧)

Job 是在数据库创建的时候自动创建,并由Scheduler来管理。Scheduler maintenance windows open时运行gather job 默认情况下,job 会在每天晚上10到早上6点和周末全天开启。该过程首先检测统计信息缺失和陈旧的对象。然后确定优先级,再开始进行统计信息。

Scheduler Job stop_on_window_close 属性控制GATHER_STATS_JOB 是否继续。该属性默认值为True. 如果该值设置为False,那么GATHER_STATS_JOB 会中断, 而没有收集完的对象将在下次启动时继续收集。

Gather_stats_job 调用dbms_stats.gather_database_stats_job_proc过程来收集statistics 的信息。 该过程收集对象statistics的条件如下:

1)对象的统计信息之前没有收集过。

2当对象有超过10%rows 被修改,此时对象的统计信息也称为stale statistics

Oracle 10g中,在查询表时,如果没有统计分析,那么会采用动态采样。

Oracle 分析及动态采样

http://blog.csdn.net/tianlesoftware/archive/2010/08/28/5845028.aspx

以上说明,都是讲Oracle 自动收集这块,但有时候,自动收集也不太靠谱,因为默认情况下只在晚上10点到早上6点。 如果在其他时间表的更新很频繁,这样数据的信息也不准确。 产生的执行计划可能与实际的也就可能有出入。

. 手工收集统计信息脚本

一般情况下,当表分析以后,在查看dba_tables 表的num_rows 列时会显示表中记录数,我们可以拿这个数值与count(*) 的结果进行比较,如果2者相差较大,就说明,该表的统计信息陈旧,需要去收集统计信息。

2.1 存储过程

CREATE OR REPLACE PROCEDURE proc_manual_gather_stats

AS

t_count number;

t_num_rows number;

t_tablename varchar2(50);

t_sql varchar2(200);

CURSOR c1 IS select * from dba_tables where owner='DAVE';

BEGIN

/**

过程内容: 判断统计信息是否同步,如不同步,手工收集统计信息

作者: Tianlesoftware

时间:2011-5-25

*/

FOR x IN c1

LOOP

t_tablename := x.TABLE_NAME;

t_num_rows := x.num_rows;

t_sql :='select count(*) from '||t_tablename;

Execute immediate t_sql into t_count ;

--DBMS_OUTPUT.PUT_LINE( 't_tablename:--'|| t_tablename ||'--'||' t_num_rows is:t_count :-- '|| t_num_rows ||': ' || t_count );

if abs(t_count - t_num_rows) >=10000 then

-- 当统计信息中的记录数与表中实际的记录数差距超过10000时,就分析该表

dbms_stats.gather_table_stats('DAVE',t_tablename);

end if;

END LOOP;

EXCEPTION

WHEN NO_DATA_FOUND

THEN

DBMS_OUTPUT.PUT_LINE ('NO_DATA_FOUND');

RETURN;

WHEN OTHERS

THEN

DBMS_OUTPUT.PUT_LINE ('OTHERS');

RETURN;

END;

/

2.2 使用Scheduler Job 部署

Oracle 10g Scheduler 特性

http://blog.csdn.net/tianlesoftware/archive/2009/10/22/4715218.aspx

2.2.1 创建Job

BEGIN

DBMS_SCHEDULER.CREATE_JOB (

job_name => 'JOB_MANUAL_GATHER_STATS',

job_type => 'STORED_PROCEDURE',

job_action => 'PROC_MANUAL_GATHER_STATS', --调用的过程名称

start_date => sysdate,

repeat_interval => ''FREQ=HOURLY;INTERVAL=1');

-- 每个一小时执行一次

END;

/

这个时间要根据自己的业务来判断,因为分析本身就会消耗CPU 资源。 所以尽量避免业务高峰期来执行,最好是在业务低的时候执行。

注意:

JOB 虽然成功创建了,但却并未执行.因为ENABLED 参数当不显式指定时,该参数的默认值为false

2.2.2 启用Job

exec dbms_scheduler.enable('JOB_MANUAL_GATHER_STATS');

2.2.3 停止Job

exec dbms_scheduler.disable('JOB_MANUAL_GATHER_STATS');

-------------------------------------------------------------------------------------------------------

Blog http://blog.csdn.net/tianlesoftware

Email: dvd.dba@gmail.com

DBA1 群:62697716(); DBA2 群:62697977() DBA3 群:62697850()

DBA 超级群:63306533(); DBA4 群: 83829929 DBA5群: 142216823

DBA6 群:158654907 聊天 群:40132017 聊天2群:69087192

--加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请

分享到:
评论

相关推荐

    使用dbms_stats包手工收集统计信息

    Oracle 数据库中使用 dbms_stats 包手动收集统计信息 在 Oracle 数据库中,dbms_stats 包提供了一种手动收集统计信息的方式,包括基于表、用户和索引的统计信息。通过使用 dbms_stats 包,我们可以手动收集统计信息...

    oracle 性能数据自动收集脚本

    10.Oracle深度学习笔记——Oracle自动统计数据采集脚本 的附件

    Oracle 11g R2 手动建库脚本

    Oracle 11g R2 手动建库脚本是一个重要的数据库管理任务,涉及一系列复杂的步骤和技术细节。在这个过程中,数据库管理员(DBA)需要创建一个新的数据库实例,配置相关的参数,分配存储空间,并确保所有安全性和性能...

    Oracle 11G统计信息自动收集及调整

    文档里包含Oracle 11G统计信息自动收集及调整,可以使用优化数据库性能,不合理的统计信息会影响数据库性能

    nacos 适配 oracle 11g版本 ,附带oracle 脚本,亲测可用

    本教程将详细介绍如何在Nacos中适配Oracle 11g,并提供亲测可用的Oracle脚本。 首先,我们需要了解Nacos对数据库的依赖。Nacos默认使用H2数据库进行存储,但为了满足大规模生产环境的需求,通常会选择更为强大的...

    oracle 手动启动数据库脚本

    Oracle数据库是全球广泛使用的大型关系型数据库管理系统,其稳定性和高效性备受赞誉。然而,在某些情况下,数据库可能无法在系统启动时自动启动,这可能是由于多种原因,如系统故障、配置错误或数据库自身的异常状态...

    oracle导入详细脚本

    Oracle导入详细脚本 Oracle导入详细脚本 Oracle导入详细脚本

    Oracle常用脚本与语句

    Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句Oracle常用脚本与语句...

    oracle手动创建数据库脚本

    手动创建数据库脚本 100%成功 相应的细节你可以自己该一下

    oracle批量插入数据脚本

    oracle批量生成数据脚本,oracle批量生成数据脚本,oracle批量生成数据脚本,oracle批量生成数据脚本。

    oracle 自动收集统计信息 测试

    Oracle 自动收集统计信息测试 Oracle 自动收集统计信息是 Oracle 数据库中的一种功能,可以自动收集数据库中的统计信息,以便提高查询性能和优化数据库性能。在本文中,我们将对 Oracle 自动收集统计信息进行测试,...

    Oracle 常用脚本.zip

    4. 备份与恢复脚本:Oracle的RMAN(恢复管理器)提供了强大的备份和恢复功能,相关脚本可以帮助我们定期备份数据库,并在系统故障时快速恢复数据。 5. 性能监控脚本:包括AWR(自动工作负载存储库)报告生成脚本、...

    windows环境下Oracle数据库的自动备份脚本

    windows环境下Oracle数据库的自动备份脚本

    Oracle数据库RAC健康检查脚本

    Oracle数据库RAC(Real Application Clusters)健康检查脚本是一种重要的工具,用于DBA(数据库管理员)对数据库系统进行全面的性能监控和问题排查。RAC是Oracle数据库的一个关键特性,它允许多个实例同时访问同一...

    oracle11g一键安装脚本

    oracle11g centos7一键安装脚本,脚本里面有完整安装提示说明。大概步骤如下 1、关闭防火墙 2、设置服务器名称并增加映射 3、安装Oracle所需的依赖 4、解压oracle安装包 5、创建用户和组 6、修改内核参数 7、修改用户...

    ORACLE数据库备份用bat脚本

    本文将详细讲解如何利用批处理脚本(BAT)进行Oracle数据库的备份,并探讨如何通过Java代码实现定时备份。 首先,让我们理解"Oracle数据库备份用bat脚本"的概念。批处理脚本是Windows操作系统中的一种命令文件,...

    获取oracle表空间脚本

    在进行数据库备份与恢复的过程中,经常需要获取当前Oracle数据库中的表空间信息及其创建脚本。这样做的目的是为了确保在恢复过程中能够快速重建原有的数据库环境,包括表空间、用户以及其他数据库对象。本文将详细...

    windows下oracle11g数据泵自动备份脚本

    windows下oracle11g数据泵自动备份脚本含删除过期备份和使用方法 1、先建备份用的路径对象:(注:此处认为用来做备份的用户backupuser已经建好了,且已经有连接数据库的相应权限) sqlplus / as sysdba CREATE OR ...

    定时导出Oracle数据库数据并上传到FTP目录脚本

    脚本首先设置了Oracle连接的相关信息,然后执行SQL查询并将结果保存到指定的输出文件。`WHENEVER`语句用于在遇到错误时退出脚本,`SPOOL`命令则用来控制输出。 然后,我们需要将这个TXT文件上传到FTP服务器。这可以...

    获取ORACLE信息的脚本

    一个获取全面数据库信息的脚本,用文本文件打开。在sqlplus下执行使用sys帐号。可以在当前目录下获得html文件大于8M之多

Global site tag (gtag.js) - Google Analytics