Oracle手工生成段建议(Segment Advisor)


转载: 原文地址: http://blog.csdn.net/oradh/article/details/26213825


一、描述
从oracle 10g开始,oracle引入了段顾问(Segment Advisor),用于检查数据库中是否有与存储空间相关的建议,并且从10gR2开始,oracle自动调度并运行一个段顾问作业,定时分析数据库中的段,并将分析结果放在内部表中。但是很多情况下,作为DBA,我们都会将oracle自带的各种调度作业(统计信息收集、段顾问、SQL顾问等等)禁用,进而通过手工进行控制执行类似作业(或者为了节省资源)。因此很多情况下,我们都没有用到段顾问这个非常实用的功能。这篇文章就是讲述在表对象和表空间级别通过手工运行段顾问来生成段建议的方法。
二、作用
  • 优化SQL语句时,可以帮助我们更准确的判断是否需要回收表内的碎片空间。如果不运行段顾问建议,我们必须得通过create table as select一张临时表方式才能准确的得知是否有必要进行表空间回收,以及空间的回收率等等信息。
  • 优化SQL语句时,可以帮助我们准确判断是否需要重建或者move表来消除表内的行链接。可以想想,如果没有这个建议,我们又需要做多少工作来判断。
  • 日常主动维护时,可以帮助我们主动发现表内碎片较多和行链接较严重的表对象列表,有助于我们提前处理,避免类似问题的发生。
三、段顾问的分析结果类型
  • 适合进行段收缩操作来回收空间的段
  • 具有大量行链接的段
  • 可能会从OLTP压缩中受益的段
四、手工运行段顾问步骤
  1. 创建一个段顾问任务
  2. 为这个任务分配一个对象(指定以表对象或者表空间级别来运行,同时制定用户名和表名或者表空间名)
  3. 设置任务参数(执行段顾问执行时的一些参数,例如:运行时长限制参数、仅生产与空间相关建议/所有类型的对象生成建议)
  4. 执行这个任务
五、手工运行段顾问的代码
declare
  my_task_id  number;
  obj_id  number;
  my_task_name varchar2( 100);
  my_task_desc varchar2( 500);
begin
  my_task_name : = 'advisor_test tab Advice';   - -运行任务名,可以任意指定,不过建议为有意义的名称
  my_task_desc : = 'Manual Segment Advisor Run'; - -运行任务描述,可以任意指定,不过建议为有意义的描述
- - - - -step  1
   / * 创建一个段顾问任务  * /
  dbms_advisor.create_task(
  advisor_name  = >  'Segment Advisor',   - -运行段顾问任务这个参数必须指定为Segment Advisor
  task_id  = > my_task_id,
  task_name  = > my_task_name,
  task_desc  = >my_task_desc);
- - - - -step  2
   / * 为这个任务分配一个对象  * /
  dbms_advisor.create_object(
  task_name = >my_task_name,
  object_type = > 'TABLE',        - -指定对象级别,如果为表对象则为 'TABLE',如果为表空间级别则为 'TABLESPACE'
  attr1 = > 'DBMON',              - - -如果在表对象级别运行,这个属性为用户名,表空间级别这个属性为表空间名字
  attr2  = >  'ADVISOR_TEST',     - - -如果在表对象级别运行,这个属性为表名,表空间级别这个属性为 null
  attr3  = >  NULL,
  attr4 = > null,
  attr5 = > null,
  object_id = >obj_id);
- - - - -step  3
/ * 设置任务参数  * /
  dbms_advisor.set_task_parameter(
  task_name  = > my_task_name,
/ * 设置段顾问运行参数 "ecommend_all"的值,为 TRUE则为所有类型的对象的生成建议,为 FALSE则仅生成与空间相关的建议  * /
/ * 另一个滚问运行参数 "time_limit",制定顾问运行的时间限制,默认值为无限制  * /
   parameter = > 'recommend_all',   - - -
   value = > 'TRUE');
- - - - -step  4
/ * 执行这个任务  * /
  dbms_advisor.execute_task(my_task_name);
end;
/

六、查询段顾问分析结果的语句
( 1)
select 
   / *  "|chr(13)||chr(10)"为windows平台的换行符,如果是linux等其它平台,请用 "chr(10)"代替  * /
  'Task name     :'||f.task_name||chr( 13)||chr( 10)||  
  'Segment name  :'||o.attr2    ||chr( 13)||chr( 10)||
  'Sement type   :'||o. type     ||chr( 13)||chr( 10)||
  'partition name:'||o.attr3    ||chr( 13)||chr( 10)||
  'Message       :'||f.message  ||chr( 13)||chr( 10)||
  'More info     :'||f.more_info TASK_ADVICE
  from dba_advisor_findings f,dba_advisor_objects o
where o.task_id =f.task_id
   and o.object_id =f.object_id
   and f.task_name  =  'advisor_test tab Advice'
order  by f.task_name;
( 2
通过查询 TABLE(dbms_space.asa_recommendations(all_runs = > 'TRUE',show_manual = > 'TRUE',show_findings = > 'FALSE'))来查看建议;
第一个参数 true表示运行历次运行结果, false表示最近一次的结果
第二个参数 true表示返回手工运行段顾问的结果, false表示返回自动运行段顾问的结果
第三个参数 true表示仅显示分析结果, false表示显示分析结果和分析建议
备注:案例中使用(1)语句来查看分析结果

七、 案例1(表对象级别运行)
SQL >  create  table advisor_test  as  select  *  from dba_objects;
Table created
SQL >  insert  into advisor_test  select  *  from advisor_test;
72525  rows inserted
SQL >  /
145050  rows inserted
SQL >  /
290100  rows inserted
SQL >  commit;
Commit complete
SQL >  delete advisor_test  where rownum < 100000;
99999  rows deleted
SQL >  /
99999  rows deleted
SQL >  commit;
Commit complete

declare
  my_task_id  number;
  obj_id  number;
  my_task_name varchar2( 100);
  my_task_desc varchar2( 500);
begin
  my_task_name : = 'advisor_test tab Advice';
  my_task_desc : = 'Manual Segment Advisor Run';
- - - - -step  1
  dbms_advisor.create_task(
  advisor_name  = >  'Segment Advisor',
  task_id  = > my_task_id,
  task_name  = > my_task_name,
  task_desc  = >my_task_desc);
- - - - -step  2
  dbms_advisor.create_object(
  task_name = >my_task_name,
  object_type = > 'TABLE',
  attr1 = > 'DBMON',
  attr2  = >  'ADVISOR_TEST',
  attr3  = >  NULL,
  attr4 = > null,
  attr5 = > null,
  object_id = >obj_id);
- - - - -step  3
  dbms_advisor.set_task_parameter(
  task_name  = > my_task_name,
   parameter = > 'recommend_all',
   value = > 'TRUE');
- - - - -step  4
  dbms_advisor.execute_task(my_task_name);
end;
/
已执行



SQL >  select
   2     / *  "|chr(13)||chr(10)"为windows平台的换行符,如果是linux等其它平台,请用 "chr(10)"代替  * /
   3    'Task name     :'||f.task_name||chr( 13)||chr( 10)||
   4    'Segment name  :'||o.attr2    ||chr( 13)||chr( 10)||
   5    'Sement type   :'||o. type     ||chr( 13)||chr( 10)||
   6    'partition name:'||o.attr3    ||chr( 13)||chr( 10)||
   7    'Message       :'||f.message  ||chr( 13)||chr( 10)||
   8    'More info     :'||f.more_info TASK_ADVICE
   9    from dba_advisor_findings f,dba_advisor_objects o
  10   where o.task_id =f.task_id
  11     and o.object_id =f.object_id
  12     and f.task_name  =  'advisor_test tab Advice'
  13   order  by f.task_name;

TASK_ADVICE
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Task  name     :advisor_test tab Advice
Segment  name  :ADVISOR_TEST
Sement  type   : TABLE
partition  name:
Message       :启用表 DBMON.ADVISOR_TEST 的行移动并执行收缩, 估计可以节省  285435
31 字节。
More info     :分配空间: 75497472: 已用空间: 46953941: 可回收空间: 28543531:

八、案例2(表空间级别运行)
declare
  my_task_id  number;
  obj_id  number;
  my_task_name varchar2( 100);
  my_task_desc varchar2( 500);
begin
  my_task_name : = 'Tablespace Advice';
  my_task_desc : = 'Manual Segment Advisor Run';
- - - - -step  1
  dbms_advisor.create_task(
  advisor_name  = >  'Segment Advisor',
  task_id  = > my_task_id,
  task_name  = > my_task_name,
  task_desc  = >my_task_desc);
- - - - -step  2
  dbms_advisor.create_object(
  task_name = >my_task_name,
  object_type = > 'TABLESPACE',
  attr1 = > 'USERS',
  attr2  = >  null,
  attr3  = >  NULL,
  attr4 = > null,
  attr5 = > null,
  object_id = >obj_id);
- - - - -step  3
  dbms_advisor.set_task_parameter(
  task_name  = > my_task_name,
   parameter = > 'recommend_all',
   value = > 'TRUE');
- - - - -step  4
  dbms_advisor.execute_task(my_task_name);
end;
/



SQL >  select
   2     / *  "|chr(13)||chr(10)"为windows平台的换行符,如果是linux等其它平台,请用 "chr(10)"代替  * /
   3    'Task name     :'||f.task_name||chr( 13)||chr( 10)||
   4    'Segment name  :'||o.attr2    ||chr( 13)||chr( 10)||
   5    'Sement type   :'||o. type     ||chr( 13)||chr( 10)||
   6    'partition name:'||o.attr3    ||chr( 13)||chr( 10)||
   7    'Message       :'||f.message  ||chr( 13)||chr( 10)||
   8    'More info     :'||f.more_info TASK_ADVICE
   9    from dba_advisor_findings f,dba_advisor_objects o
  10   where o.task_id =f.task_id
  11     and o.object_id =f.object_id
  12     and f.task_name  =  'Tablespace Advice'
  13   order  by f.task_name;

TASK_ADVICE
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Task  name     :Tablespace Advice
Segment  name  :T_SCEGAOKAOQUERY_GZ
Sement  type   : TABLE
partition  name:
Message       :此对象中的空闲空间小于  10MB
More info     :分配空间: 65536: 已用空间: 8192: 可回收空间: 57344:

Task  name     :Tablespace Advice
Segment  name  :T_SCEGAOKAOQUERY_GZ
Sement  type   : TABLE
partition  name:

TASK_ADVICE
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Message       :此对象中的空闲空间小于  10MB
More info     :分配空间: 3145728: 已用空间: 2871921: 可回收空间: 273807:

Task  name     :Tablespace Advice
Segment  name  :T_SCEGAOKAOQUERY
Sement  type   : TABLE
partition  name:
Message       :此对象中的空闲空间小于  10MB
More info     :分配空间: 46137344: 已用空间: 44837534: 可回收空间: 1299810:
- - - - - - - -为了排版,省略后面的输出 - - - - - - - - - - - - - -

备注:最后可以运行delete_task来删除任务,如下exec dbms_advisor.delete_task(task_name => 'Tablespace Advice');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值