一、描述
二、作用
三、段顾问的分析结果类型
四、手工运行段顾问步骤
五、手工运行段顾问的代码
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)语句来查看分析结果