sql tuning advisor使用
DB tuning advisor是创建优化任务,对某些sql数据库进行分析,并尽量给出优化建议的一个强大的数据库工具。
自己平时几乎没用过这玩意,所以来测一测用法,其实对于一些sql一筹莫展的时候跑跑这个,看看数据库的建议也是一个突破点。
一般利用database tuning advisor的顺序:
- 找出要去优化调整的sql_id,创建优化任务
Login as SYSTEM (or any other user) at sqlplus and create the tuning task:
SET SERVEROUTPUT ON
declare
stmt_task VARCHAR2(40);
begin
stmt_task := DBMS_SQLTUNE.CREATE_TUNING_TASK(sql_id => 'gf27vxf3rz2x7',time_limit=>600);
DBMS_OUTPUT.put_line('task_id: ' || stmt_task );
end;
/
task_id: TASK_43083
注:time_limit以秒为单位,就是这个优化任务最多跑多久,最大3600S,但一般都很快可以跑完,当然在跑这个优化任务的时候,数据库会去模拟执行sql或者其中一部分。
当然也可以直接把sql text作为输入
2. Run the SQL TUNING TASK
begin
DBMS_SQLTUNE.EXECUTE_TUNING_TASK(task_name => 'TASK_43083');
end;
/
3. monitor the processing of the tuning task with the statement
SELECT TASK_NAME, STATUS FROM DBA_ADVISOR_LOG WHERE TASK_NAME = 'TASK_43083';
SELECT status FROM dba_ADVISOR_TASKS WHERE task_name ='TASK_43083';
4. When the task has a status=COMPLETED, then run:
SELECT DBMS_SQLTUNE.REPORT_TUNING_TASK('TASK_43083') AS recommendations FROM dual;
5. Examine the recommendations from Oracle, in case you agree, then accept the best SQL profile.
begin
DBMS_SQLTUNE.ACCEPT_SQL_PROFILE(task_name => 'TASK_43083', task_owner => 'SYSTEM', replace => TRUE);
end;
/
6. You can check the database sql profiles with the statement:
select * from dba_sql_profiles;
In case you want to disable an sql profile use the statement:
begin
DBMS_SQLTUNE.ALTER_SQL_PROFILE('SQL_PROFILE','STATUS','DISABLED');
end;
/
========================================================
如下是实际在sqlplus和OEM下的操作:
SQL> SET SERVEROUTPUT ON
SQL> declare
2 stmt_task VARCHAR2(40);
3 begin
stmt_task := DBMS_SQLTUNE.CREATE_TUNING_TASK(sql_id => 'gf27vxf3rz2x7',time_limit=>600);
DBMS_OUTPUT.put_line('task_id: ' || stmt_task );
end;
/ 4 5 6 7
task_id: TASK_43083
PL/SQL procedure successfully completed.
SQL> begin
2 DBMS_SQLTUNE.EXECUTE_TUNING_TASK(task_name => 'TASK_43083');
3 end;
/ 4
PL/SQL procedure successfully completed.
SQL> SELECT status FROM dba_ADVISOR_TASKS WHERE task_name ='TASK_43083';
STATUS
-----------
COMPLETED
SQL> SELECT TASK_NAME, STATUS FROM DBA_ADVISOR_LOG WHERE TASK_NAME = 'TASK_43083';
TASK_NAME STATUS
------------------------------ -----------
TASK_43083 COMPLETED
SQL> SELECT DBMS_SQLTUNE.REPORT_TUNING_TASK('TASK_43083') AS recommendations FROM dual;
RECOMMENDATIONS
--------------------------------------------------------------------------------
GENERAL INFORMATION SECTION
----------------------------------------------------
在这里没有recommend推荐,所以没内容
SQL> SELECT * FROM DBA_ADVISOR_TASKS T WHERE TASK_NAME='TASK_43083';
OWNER TASK_ID TASK_NAME DESCRIPTION ADVISOR_NAME CREATED LAST_MODI PARENT_TASK_ID PARENT_RXEC_ID LAST_EXECUTION EXECUTION_TYPE EXECUTION_TYPE# EXECUTION_DESCRIPTION EXECUTION EXECUTION STATUS
----------------------------------------------------------------- ------------------------------ --------- --------- -------------- -------------- ------------------------------ ------------------------------ --------------- ---------------------------------------STATUS_MESSAGE
PCT_COMPLETION_TIME PROGRESS_METRIC METRIC_UNITS ACTIVITY_COUNTER RECOMMENDATION_COUNT
------------------- --------------- ---------------------------------------------------------------- ---------------- --------------------
ERROR_MESSAGE
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------SOURCE HOW_CREATED READ_ SYSTE ADVISOR_ID STATUS#
------------------------------ ------------------------------ ----- ----- ---------- ----------
SYS 43083 TASK_43083 SQL Tuning Advisor 21-DEC-16 21-DEC-16 0 0 EXEC_43064 TUNE SQL 1 21-DEC-16 21-DEC-16 COMPLETED
0 0 0 0
CMD FALSE FALSE 4 3
从这里也可以看到RECOMMENDATION_COUNT为0,说明tuning advisor没啥建议。Task name为TASK_43083,task id为43083.
SQL> SELECT * FROM DBA_SQLTUNE_STATISTICS;
TASK_ID OBJECT_ID PARSING_SCHEMA_ID MODULE ACTION ELAPSED_TIME CPU_TIME BUFFER_GETS DISK_READS DIRECT_WRITES ROWS_PROCESSED FETCHES EXECUTIONS END_OF_FETCH_COUNT OPTIMIZER_COST OPTIMIZER_ENV COMMAND_TYPE
---------- ---------- ----------------- ---------------------------------------------------------------- ---------------------------------------------------------------- ------------ ---------- ----------- ---------- ------------- -------------- ---------- ---------- ------------------ -------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- ------------
43083 1 JDBC Thin Client 4.3835E+10 1879546000 143899706 143034103 0 20730472 20732 4 4 657055 E289FB89E426A8004E011000AEF5C3E2CFFA331056414551519521105555551545545558591555449665851D5511058555555155515122555415A0EA0C55514542654554544490A1566E021696C6A75545150502541552441615579110A8456E820A5000030020000000000100001000000002002080007D000000000032000 3
SQL> SELECT * FROM DBA_SQLTUNE_BINDS;
no rows selected
SQL> SELECT * FROM DBA_SQLTUNE_PLANS WHERE TASK_ID='43083';
SQL> SELECT TO_CHAR(execution_start,'dd-mon-yyyy hh24:mi:ss') || ' -> ' || TO_CHAR(execution_end,'dd-mon-yyyy hh24:mi:ss') AS execution_time,
2 status,status_message,pct_completion_time
3 FROM DBA_ADVISOR_LOG
WHERE task_name='TASK_43083'; 4
EXECUTION_TIME STATUS
-------------------------------------------------------------- -----------
STATUS_MESSAGE
------------------------------------------------------------------------------------
PCT_COMPLETION_TIME
-------------------
21-dec-2016 08:45:18 -> 21-dec-2016 08:45:33 COMPLETED
0
================================================
USED SQL SUMMARY:
SELECT * FROM DBA_ADVISOR_TASKS T WHERE TASK_NAME='TASK_43083';
SELECT * FROM DBA_SQLTUNE_STATISTICS
SELECT * FROM DBA_SQLTUNE_BINDS
SELECT * FROM DBA_SQLTUNE_PLANS WHERE TASK_ID='43083'
SELECT TO_CHAR(execution_start,'dd-mon-yyyy hh24:mi:ss') || ' -> ' || TO_CHAR(execution_end,'dd-mon-yyyy hh24:mi:ss') AS execution_time,
status,status_message,pct_completion_time
FROM DBA_ADVISOR_LOG
WHERE task_name='TASK_43083';
==============================================================
OEM下的就简单很多了,点几下就够了:
选择sql tuning adviser:

这里的name可以自己定义,系统也会生成,即task name
总的时间限制30mins,comprehensive的分析范围,立即分析。这些都默认的就可以。

等待一下,正在执行优化任务

这里没什么推荐的所以为空,点击SPA Validation results看看是什么

如果有recommend生成的话,这个SPA是可以给新的优化来做测试的。

sql tuning advisor使用的更多相关文章
- SQL Tuning 基础概述08 - SQL Tuning Advisor
SQL调优顾问 SQL Tuning Advisor的使用案例: 1.构建测试表T 2.定义调整任务 3.修改调整任务参数 4.执行调整任务 5.监控调整任务 6.查看调整任务建议 7.删除调整任务 ...
- 【转】使用SQL Tuning Advisor STA优化SQL
SQL优化器(SQL Tuning Advisor STA)是Oracle10g中推出的帮助DBA优化工具,它的特点是简单.智能,DBA值需要调用函数就可以给出一个性能很差的语句的优化结果.下面介绍一 ...
- 如何用 SQL Tuning Advisor (STA) 优化SQL语句
在Oracle10g之前,优化SQL是个比较费力的技术活,不停的分析执行计划,加hint,分析统计信息等等.在10g中,Oracle推出了自己的SQL优化辅助工具: SQL优化器(SQL Tuning ...
- Oracle 10G强大的SQL优化工具:SQL Tuning Advisor
p { margin-bottom: 0.25cm; direction: ltr; color: rgb(0, 0, 0); line-height: 120%; orphans: 2; widow ...
- 使用ORACLE SQL Tuning advisor快速优化低效的SQL语句
ORACLE10G以后版本的SQL Tuning advisor可以从以下四个方面给出优化方案 (1)为统计信息丢失或失效的对象收集统计信息 (2)考虑优化器的任何数据偏差.复杂谓词或失效的统计信 ...
- How to use STA(sql tuning advisor)
一.手工生成Sql tuning advisor 1.SQL text format: DECLARE my_task_name VARCHAR2(30); my_sqltext CLO ...
- Oracle调整顾问(SQL Tuning Advisor 与 SQL Access Advisor
在Oracle数据库出现性能问题时,使用Oracle本身的工具包,给出合理的调优建议是比较省力的做法. tuning advisor 是对输入的sql set的执行计划进行优化accsee advis ...
- SQL Tuning Advisor
SQL Tuning Advisorsql调优顾问可提供的建议有:-收集对象的统计信息-创建索引-重写sql语句-创建sql profile-创建sql plan baseline SQL Tunin ...
- 初次使用SQL调优建议工具--SQL Tuning Advisor
在10g中,Oracle推出了自己的SQL优化辅助工具: SQL优化器(SQL Tuning Advisor :STA),它是新的DBMS_SQLTUNE包. 使用STA一定要保证优化器是CBO模式下 ...
随机推荐
- 虚拟机利用Host-only实现在不插网线的情况下,虚拟机与主机实现双向通信,实现ssh连接以及samba服务实现共享
为了不影响其他的虚拟网卡,我们在VMware下在添加一块虚拟网卡: 然后点击Next,选择连接方式: 点击Finish即可. 重新启动虚拟机,如果这是你手动添加的第一块虚拟网卡,那么应该是eth1. ...
- 1Z0-053 争议题目解析694
1Z0-053 争议题目解析694 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 694.As part of archiving the historical data, you ...
- SSH/SSL 源码编译安装简易操作说明
环境:CentOS 6.7 安全加固需求,由于某盟扫描系统主机有SSL系列漏洞,客户要求必须修复: 解决方案:将SSH/SSL升级到最新版本,删除SSL旧版本(实测不删除旧版本某盟扫描无法通过). 当 ...
- c3p0数据库连接池的使用详解
首先,什么是c3p0?下面是百度百科的解释: C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Sp ...
- C#解决Linq OrderBy() 失效的小技巧
前言 前几天的一个数据列表中我用了Linq GroupBy 和OrderBy. 排序在本机正常使用,发到测试后排序死活不对,很是郁闷,总以为是程序问题.于是请教了另外一个同事.有了以下的答案. 问题原 ...
- Winform在线更新
引言 2015年第一篇,Winform在线更新,算是重操旧业吧,09年刚到北京时一直做硬件联动编程,所以大多数时间都在搞Winform, 但是从来没做过在线更新这个功能,前几天参与部门另一个项目,上来 ...
- Scala 中下划线的用途
转载自:https://my.oschina.net/leejun2005/blog/405305 Scala 作为一门函数式编程语言,对习惯了指令式编程语言的同学来说,会不大习惯,这里除了思维方式之 ...
- html自我设计login登录
效果图如下: 第一次设计出能看的前台,就当留作纪念吧.
- MSSQL数据库的一些基础知识
转几个关于MSSQL数据库基础的文章: sql server系统表详细说明 SQL Server中系统数据库介绍 SQL Server中的角色(服务器级别和数据库级别角色)
- 为什么,node_body.firstChild找不到table节点
在Firefox下,会把空格或者换行,当成一个文本节点.因此所有标记之间的空格和换行都去掉.