DB tuning advisor是创建优化任务,对某些sql数据库进行分析,并尽量给出优化建议的一个强大的数据库工具。

自己平时几乎没用过这玩意,所以来测一测用法,其实对于一些sql一筹莫展的时候跑跑这个,看看数据库的建议也是一个突破点。

一般利用database tuning advisor的顺序:

  1. 找出要去优化调整的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使用的更多相关文章

  1. SQL Tuning 基础概述08 - SQL Tuning Advisor

    SQL调优顾问 SQL Tuning Advisor的使用案例: 1.构建测试表T 2.定义调整任务 3.修改调整任务参数 4.执行调整任务 5.监控调整任务 6.查看调整任务建议 7.删除调整任务 ...

  2. 【转】使用SQL Tuning Advisor STA优化SQL

    SQL优化器(SQL Tuning Advisor STA)是Oracle10g中推出的帮助DBA优化工具,它的特点是简单.智能,DBA值需要调用函数就可以给出一个性能很差的语句的优化结果.下面介绍一 ...

  3. 如何用 SQL Tuning Advisor (STA) 优化SQL语句

    在Oracle10g之前,优化SQL是个比较费力的技术活,不停的分析执行计划,加hint,分析统计信息等等.在10g中,Oracle推出了自己的SQL优化辅助工具: SQL优化器(SQL Tuning ...

  4. Oracle 10G强大的SQL优化工具:SQL Tuning Advisor

    p { margin-bottom: 0.25cm; direction: ltr; color: rgb(0, 0, 0); line-height: 120%; orphans: 2; widow ...

  5. 使用ORACLE SQL Tuning advisor快速优化低效的SQL语句

    ORACLE10G以后版本的SQL Tuning advisor可以从以下四个方面给出优化方案 (1)为统计信息丢失或失效的对象收集统计信息   (2)考虑优化器的任何数据偏差.复杂谓词或失效的统计信 ...

  6. How to use STA(sql tuning advisor)

    一.手工生成Sql tuning advisor  1.SQL text format: DECLARE   my_task_name VARCHAR2(30);   my_sqltext   CLO ...

  7. Oracle调整顾问(SQL Tuning Advisor 与 SQL Access Advisor

    在Oracle数据库出现性能问题时,使用Oracle本身的工具包,给出合理的调优建议是比较省力的做法. tuning advisor 是对输入的sql set的执行计划进行优化accsee advis ...

  8. SQL Tuning Advisor

    SQL Tuning Advisorsql调优顾问可提供的建议有:-收集对象的统计信息-创建索引-重写sql语句-创建sql profile-创建sql plan baseline SQL Tunin ...

  9. 初次使用SQL调优建议工具--SQL Tuning Advisor

    在10g中,Oracle推出了自己的SQL优化辅助工具: SQL优化器(SQL Tuning Advisor :STA),它是新的DBMS_SQLTUNE包. 使用STA一定要保证优化器是CBO模式下 ...

随机推荐

  1. spring笔记--通过注解(annotation)配置Bean

    Spring能够在classpath下自动扫描,侦测和实例化具有特定注解的组件,这在Spring中成为组件扫描(Component scanning). 特定组件的注解包括: @Component:基 ...

  2. Cesium原理篇:6 Render模块(5: VAO&RenderState&Command)

    VAO VAO(Vertext Array Object),中文是顶点数组对象.之前在<Buffer>一文中,我们介绍了Cesium如何创建VBO的过程,而VAO可以简单的认为是基于VBO ...

  3. Spinner控件

    首先在XML文件中声明一个Spinner控件: <Spinner android:id="@+id/spinnerId" android:layout_width=" ...

  4. PopupWindow 点击外部和返回键无法消失背后的真相(setBackgroundDrawable(Drawable background))

    刚接手PopupWindow的时候,我们都可能觉得很简单,因为它确实很简单,不过运气不好的可能就会踩到一个坑: 点击PopupWindow最外层布局以及点击返回键PopupWindow不会消失 新手在 ...

  5. Bootstrap 3.0正式版发布!

    Bootstrap是Twitter推出的一个开源的用于前端开发的工具包,包含了丰富的Web组件.根据这些组件,开发者可以快速的搭建一个漂亮.功能完备的网站.在经过Bootstrap 3 RC版的测试和 ...

  6. Get和Post区别

    1. get是从服务器上获取数据,post是向服务器传送数据.2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到.post是通过H ...

  7. 艾伦 Visual Studio 批量自动化代码操作工具-VS插件发布

    艾伦 Visual Studio 批量自动化代码操作工具 以下简称--艾伦工具箱. 艾伦工具箱是一个多文件批量处理插件,目的是为了广大开发者提高开发效率,减少项目代码规范化审计,缩短开发者的项目开发周 ...

  8. The SQL Server Service Broker for the current database is not enabled

    把一个数据恢复至另一个服务器上,出现了一个异常: The SQL Server Service Broker for the current database is not enabled, and ...

  9. Linux查看CPU和内存使用情况(转)

    在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会 ...

  10. Redis安装配置

    Redis有服务端和客户端 服务端: 服务端下载地址: https://github.com/dmajkic/redis/downloads 解压后: 然后进入CMD命令: 不要关闭此命令窗(关闭服务 ...