dbms_advisor 手动生成段顾问建议!
执行包需要dbms_advisor权限:
- sys@ORCL> grant advisor to u1;
- 授权成功。
创建段顾问任务,指定create_task的advisor_name参数为“段顾问”。查询dba_advisor_definitions来获得所有有效的顾问列表。
- u1@ORCL> select * from dba_advisor_definitions;
- ADVISOR_ID ADVISOR_NAME PROPERTY
- ---------- ------------------------------ ----------
- 1 ADDM 1
- 2 SQL Access Advisor 271
- 3 Undo Advisor 1
- 4 SQL Tuning Advisor 935
- 5 Segment Advisor 3
- 6 SQL Workload Manager 0
- 7 Tune MView 31
- 8 SQL Performance Analyzer 935
- 9 SQL Repair Advisor 679
- 10 Compression Advisor 3
- 已选择10行。
手动执行段顾问:
- sys@ORCL> DECLARE
- 2 my_task_id number;
- 3 obj_id number;
- 4 my_task_name varchar2(100);
- 5 my_task_desc varchar2(500);
- 6 BEGIN
- 7 my_task_name := 'BIG_TABLE Advice';
- my_task_desc := 'Manual Segment Advisor Run';
- 9 ---------
- 10 -- Step 1 创建一个任务
- 11 ---------
- 12 dbms_advisor.create_task (
- 13 advisor_name => 'Segment Advisor',
- 14 task_id => my_task_id,
- 15 task_name => my_task_name,
- 16 task_desc => my_task_desc);
- 17 ---------
- 18 -- Step 2 为这个任务分配一个对象
- 19 ---------
- 20 dbms_advisor.create_object (
- 21 task_name => my_task_name,
- 22 object_type => 'TABLE',
- 23 attr1 => 'U1',
- 24 attr2 => 'BIG_TABLE',
- 25 attr3 => NULL,
- 26 attr4 => NULL,
- 27 attr5 => NULL,
- 28 object_id => obj_id);
- 29 ---------
- 30 -- Step 3 设置任务参数
- 31 ---------
- 32 dbms_advisor.set_task_parameter(
- 33 task_name => my_task_name,
- 34 parameter => 'recommend_all',
- value => 'TRUE');
- ---------
- 37 -- Step 4 执行这个任务
- 38 ---------
- 39 dbms_advisor.execute_task(my_task_name);
- 40 END;
- 41 /
- PL/SQL 过程已成功完成。
- sys@ORCL> SELECT
- 2 'Segment Advice --------------------------'|| chr(10) ||
- 3 'TABLESPACE_NAME : ' || tablespace_name || chr(10) ||
- 4 'SEGMENT_OWNER : ' || segment_owner || chr(10) ||
- 5 'SEGMENT_NAME : ' || segment_name || chr(10) ||
- 6 'ALLOCATED_SPACE : ' || allocated_space || chr(10) ||
- 7 'RECLAIMABLE_SPACE: ' || reclaimable_space || chr(10) ||
- 8 'RECOMMENDATIONS : ' || recommendations || chr(10) ||
- 9 'SOLUTION 1 : ' || c1 || chr(10) ||
- 10 'SOLUTION 2 : ' || c2 || chr(10) ||
- 11 'SOLUTION 3 : ' || c3 Advice
- 12 FROM
- 13 TABLE(dbms_space.asa_recommendations('TRUE', 'TRUE', 'FALSE'));
- ADVICE
- --------------------------------------------------------------------------------
- Segment Advice --------------------------
- TABLESPACE_NAME : USERS
- SEGMENT_OWNER : QYV
- SEGMENT_NAME : BIG_TABLE
- ALLOCATED_SPACE : 125829120
- RECLAIMABLE_SPACE: 81788928
- RECOMMENDATIONS : 压缩对象 QYV.BIG_TABLE, 估计可以节省 81788928 字节。
- SOLUTION 1 : alter table "QYV"."BIG_TABLE" compress for oltp
- SOLUTION 2 : alter table "QYV"."BIG_TABLE" move
- SOLUTION 3 :
- Segment Advice --------------------------
- TABLESPACE_NAME : USERS
- SEGMENT_OWNER : U1
- SEGMENT_NAME : BIG_TABLE
- ALLOCATED_SPACE : 125829120
- RECLAIMABLE_SPACE: 109535475
- RECOMMENDATIONS : 启用表 U1.BIG_TABLE 的行移动并执行收缩, 估计可以节省 10953547
- 5 字节。
- SOLUTION 1 : alter table "U1"."BIG_TABLE" shrink space
- SOLUTION 2 : alter table "U1"."BIG_TABLE" shrink space COMPACT
- SOLUTION 3 : alter table "U1"."BIG_TABLE" enable row movement
- Segment Advice --------------------------
- TABLESPACE_NAME : USERS
- SEGMENT_OWNER : U1
- SEGMENT_NAME : TT
- ALLOCATED_SPACE : 27262976
- RECLAIMABLE_SPACE: 17314513
- RECOMMENDATIONS : 启用表 U1.TT 的行移动并执行收缩, 估计可以节省 17314513 字节。
- SOLUTION 1 : alter table "U1"."TT" shrink space
- SOLUTION 2 : alter table "U1"."TT" shrink space COMPACT
- SOLUTION 3 : alter table "U1"."TT" enable row movement
- sys@ORCL> SELECT
- 2 'Task Name : ' || f.task_name || chr(10) ||
- 3 'Segment Name : ' || o.attr2 || chr(10) ||
- 4 'Segment Type : ' || o.type || chr(10) ||
- 5 'Partition Name : ' || o.attr3 || chr(10) ||
- 6 'Message : ' || f.message || chr(10) ||
- 7 'More Info : ' || f.more_info TASK_ADVICE
- 8 FROM dba_advisor_findings f
- 9 ,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 like 'BIG_TABLE Advice'
- 13 ORDER BY f.task_name;
- TASK_ADVICE
- -----------------------------------------------------------------------------------------------------------------------------------
- Task Name : BIG_TABLE Advice
- Segment Name : BIG_TABLE
- Segment Type : TABLE
- Partition Name :
- Message : 启用表 U1.BIG_TABLE 的行移动并执行收缩, 估计可以节省 109535475 字节。
- More Info : 分配空间:125829120: 已用空间:16293645: 可回收空间:109535475:
- Task Name : BIG_TABLE Advice
- Segment Name : BIG_TABLE
- Segment Type : TABLE
- Partition Name :
- Message : 启用表 U1.BIG_TABLE 的行移动并执行收缩, 估计可以节省 109535475 字节。
- More Info : 分配空间:125829120: 已用空间:16293645: 可回收空间:109535475:
删除一个任务:
- u1@ORCL> exec dbms_advisor.delete_task('BIG_TABLE Advice');
- PL/SQL 过程已成功完成。
dbms_advisor 手动生成段顾问建议!的更多相关文章
- Oracle手工生成段建议(Segment Advisor)
一.描写叙述 从oracle 10g開始,oracle引入了段顾问(Segment Advisor),用于检查数据库中是否有与存储空间相关的建议,而且从10gR2開始,oracle自己主动调度并执行一 ...
- 手动生成/etc/shadow文件中的密码
shadow文件的格式就不说了.就说说它的第二列——密码列. 通常,passwd直接为用户指定密码就ok了.但在某些情况下,要为待创建的用户事先指定密码,还要求是加密后的密码,例如kickstart文 ...
- mongoose手动生成ObjectId
用mongoose驱动保存数据,如果_id没有定义,那么在save的时候,mongoose驱动会自己生成一个_id.那么如果需要手动生成可以用mongoose.Types.ObjectId()方法. ...
- 手动生成moc文件
在VS中写Qt项目时,手动添加了一个类,由于要用到信号槽,所以需要生成相应的moc文件.写好信号槽以后,在类里面第一行应该写上Q_OBJECT关键字,编译项目会提示无法找到moc_XXX.cpp文件. ...
- 新引入thinkphp报错“应用目录[./Application/]不可写,目录无法自动生成! 请手动生成项目目录~”
新引入thinkphp报错“应用目录[./Application/]不可写,目录无法自动生成! 请手动生成项目目录~”, 其主要原因是文件夹的权限问题,手动将项目文件夹权限更改为可读可写就OK,具体操 ...
- Hyperledger Fabric手动生成CA证书搭建Fabric网络
之前介绍了使用官方脚本自动化启动一个Fabric网络,并且所有的证书都是通过官方的命令行工具cryptogen直接生成网络中的所有节点的证书.在开发环境可以这么简单进行,但是生成环境下还是需要我们自定 ...
- 如何在Windows中手动生成SSH密钥?(转)
在Windows上,您可以通过多种方式创建SSH密钥.Windows需要SSH客户端,但在其操作系统上没有默认的SSH客户端.请注意,Windows目前正在测试本机OpenSSH应用程序,一般,不提倡 ...
- 使用Themleaf 模板引擎手动生成html文件
1.为什么要写这一篇呢? 在做一个邮件发送功能的时候,需要发送html邮件,javaMail 发送html 的时候需要有已经生成的html正文,所以需要提前将要发送的内容生成,所以就需要模板引擎来动态 ...
- 手动生成WebService代理类
方式一: 手动生成WebService代理类需要把一句生成语句,如 wsdl.exe /l:cs /out:D:/ProxyServices.cs http://localhost/WebServic ...
随机推荐
- Easyui Datagrid相同连续列合并扩展(三)
function MergeCells(seletor, rows, fields) { if(rows == null || rows.length == 0 || fields == null | ...
- WORD里怎样能做到局部“分栏”就是一页里有的分有的不分
选中你要分的部分再分栏如果不想分的部分也被分了,那就可以选中不想分的那部分,选择“分栏”->“一栏” 转自:http://zhidao.baidu.com/question/9873268.ht ...
- Pecan
什么是peacn Pecan是一个轻量级的基于Python的Web框架, Pecan的目标并不是要成为一个“full stack”的框架, 因此Pecan本身不支持类似Session和Database ...
- Amazon(vpc)对等网络
对等连接测试 1.1 东京账户A创建对等连接 注意,双方的vpc网段不能重复,如果重复会造成无法配置路由表 输入双方信息 账户ID和VPC 1.2 东京账户A查看 查看连接信息 显示正在处理接受,需要 ...
- 使用cordova+Ionic+AngularJs进行Hybird App开发的环境搭建手冊
一.所需工具 1,JDK:生成 2.安卓SDK开发环境 3,NodeJs:主要使用的还是npm 4,Python开发环境 5.VS 2012(2008,2015也能够,已亲測):安装这个主要是须要一些 ...
- Android笔记——Activity中的回传数据案例(装备选择)
1.创建程序: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns: ...
- 如何正确设置 Informix GLS 及 CSDK 语言环境
本文介绍 GLS 相关知识,说明如何正确设置 Informix GLS 语言环境相关变量(DB_LOCALE,CLIENT_LOCALE),保证 Informix 数据库服务器.客户端能正确的支持中文 ...
- sessionStorage存储json对象
应用场景: 账单列表中A页面:点击其中的一列,ajax返回的数据在这一页 点击进入账单详情B页面: 因为在A页面已经做过ajax的请求了,所以希望把当前其中的一个数组对象传到B页面中,所以,就考虑到暂 ...
- mysql支持跨表删除多条记录
在Mysql4.0之后,mysql开始支持跨表delete. Mysql可以在一个sql语句中同时删除多表记录,也可以根据多个表之间的关系来删除某一个表中的记录. 假定我们有两张表:Product表和 ...
- 160519、Oracle中将查询出的多条记录的某个字段拼接成一个字符串的方法
with temp as( select 'China' nation ,'Guangzhou' city from dual union all select 'China' nation ,'Sh ...