SQL Profile就是为某一SQL语句提供除了系统统计信息、对象(表和索引等)统计信息之外的其它信息,比方执行环境、额外的更准确的统计信息,以帮助优化器为SQL语句选择更适合的执行计划。

SQL Profiles可以说是Outlines的进化。Outlines可以实现的功能SQL Profiles也全然可以实现,而SQL Profiles具有Outlines不具备的优化,最重要的有二点:

    SQL Profiles更easy生成、更改和控制。

SQL Profiles在对SQL语句的支持上做得更好。也就是适用范围更广。

使用SQL Profiles两个目的:

    锁定或者说是稳定运行计划。

在不能改动应用中的SQL的情况下使SQL语句按指定的执行计划执行。

參考老熊的博客。链接:http://www.laoxiong.net/sql-profiles-partii.html    http://www.laoxiong.net/sql-profiles-part.html   http://blog.sina.com.cn/s/blog_5037eacb01011mgu.htm

1.实验环境构造语句:

create table bys.t1 as select * from dba_objects;

create index bys.t1_idx on t1(object_id);

exec dbms_stats.gather_table_stats('bys','t1',cascade=>true,degree=>4);

set autotrace trace;

select a.*,b.owner from t1 a,t1 b where a.object_name like '%T1%' and a.object_id=b.object_id;

select /*+ use_nl(a b) index(t2) */ a.*,b.owner from t1 a,t1 b where a.object_name like '%T1%' and a.object_id=b.object_id;

set autotrace off;

explain plan for select /*+ use_nl(a b) index(t2) */ a.*,b.owner from t1 a,t1 b where a.object_name like '%T1%' and a.object_id=b.object_id;

col sql_text for a100

SELECT SQL_ID,SQL_TEXT FROM V$SQL WHERE SQL_TEXT LIKE '%a.*,b.owner from t1 a,t1 b%';

####2t5xqt4d1dsaw

10g開始,v$sql_plan中就包含了SQL语句OUTLINE数据,也就是稳定运行计划的Hints。例如以下:

set pagesize 1000

SQL> select * from table(dbms_xplan.display_cursor('2t5xqt4d1dsaw',null,'outline'));

PLAN_TABLE_OUTPUT

---------------------------------------------------------------------------------------------------------------

SQL_ID  2t5xqt4d1dsaw, child number 0

-------------------------------------

select /*+ use_nl(a b) index(t2) */ a.*,b.owner from t1 a,t1 b where

a.object_name like '%T1%' and a.object_id=b.object_id

Plan hash value: 190596302

--------------------------------------------------------------------------------------

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

--------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT            |        |       |       |   979 (100)|          |

|   1 |  TABLE ACCESS BY INDEX ROWID| T1     |     1 |     9 |     2   (0)| 00:00:01 |

|   2 |   NESTED LOOPS              |        |   471 | 43803 |   979   (1)| 00:00:12 |

|*  3 |    TABLE ACCESS FULL        | T1     |   471 | 39564 |    36   (0)| 00:00:01 |

|*  4 |    INDEX RANGE SCAN         | T1_IDX |     1 |       |     1   (0)| 00:00:01 |

--------------------------------------------------------------------------------------



Outline Data              ----------这一部分: /*+     */ 之间的就是所需的数据了

-------------

  /*+

      BEGIN_OUTLINE_DATA

      IGNORE_OPTIM_EMBEDDED_HINTS

      OPTIMIZER_FEATURES_ENABLE('10.2.0.1')

      ALL_ROWS

      OUTLINE_LEAF(@"SEL$1")

      FULL(@"SEL$1" "A"@"SEL$1")

      INDEX(@"SEL$1" "B"@"SEL$1" ("T1"."OBJECT_ID"))

      LEADING(@"SEL$1" "A"@"SEL$1" "B"@"SEL$1")

      USE_NL(@"SEL$1" "B"@"SEL$1")

      END_OUTLINE_DATA

  */



PLAN_TABLE_OUTPUT

-----------------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("A"."OBJECT_NAME" LIKE '%T1%')

   4 - access("A"."OBJECT_ID"="B"."OBJECT_ID")

###############################################################################

2.開始创建并应用SQL Profile

使用未加HINT的SQL语句,并指定SQL_PROFILE名字:SQLPROFILE_T1

注意事项:两个引號---如('10.2.0.1')要写成(''10.2.0.1'')--'%T1%'写成''%T1%''

SQL语句结尾的;不要写上,绑定变量值是'1'时,要输入''1''

 declare

 v_hints sys.sqlprof_attr;

 begin

 v_hints:=sys.sqlprof_attr(

      'BEGIN_OUTLINE_DATA',

      'IGNORE_OPTIM_EMBEDDED_HINTS',

      'OPTIMIZER_FEATURES_ENABLE(''10.2.0.1'')',

      'ALL_ROWS',

      'OUTLINE_LEAF(@"SEL$1")',

      'FULL(@"SEL$1" "A"@"SEL$1")',

      'INDEX(@"SEL$1" "B"@"SEL$1" ("T1"."OBJECT_ID"))',

      'LEADING(@"SEL$1" "A"@"SEL$1" "B"@"SEL$1")',

      'USE_NL(@"SEL$1" "B"@"SEL$1")',

      'END_OUTLINE_DATA');

dbms_sqltune.import_sql_profile(

'select a.*,b.owner from t1 a,t1 b where a.object_name like ''%T1%'' and a.object_id=b.object_id',

v_hints,'SQLPROFILE_T1',                

force_match=>true,replace=>true);

end;

/

删除语句:

exec dbms_sqltune.drop_sql_profile(name =>'SQLPROFILE_T1' );

######

3.验证SQL语句是否使用上一步创建的SQL_PROFILE:

SQL> set autotrace trace;

SQL> select a.*,b.owner from t1 a,t1 b where a.object_name like '%T1%' and a.object_id=b.object_id;

23 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 190596302

--------------------------------------------------------------------------------------

| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |

--------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT            |        |   471 | 43803 |   979   (1)| 00:00:12 |

|   1 |  TABLE ACCESS BY INDEX ROWID| T1     |     1 |     9 |     2   (0)| 00:00:01 |

|   2 |   NESTED LOOPS              |        |   471 | 43803 |   979   (1)| 00:00:12 |

|*  3 |    TABLE ACCESS FULL        | T1     |   471 | 39564 |    36   (0)| 00:00:01 |

|*  4 |    INDEX RANGE SCAN         | T1_IDX |     1 |       |     1   (0)| 00:00:01 |

--------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("A"."OBJECT_NAME" LIKE '%T1%')

   4 - access("A"."OBJECT_ID"="B"."OBJECT_ID")

Note

-----

   - SQL profile "SQLPROFILE_T1" used for this statement



Statistics

----------------------------------------------------------

          1  recursive calls

          0  db block gets

        163  consistent gets

          0  physical reads

          0  redo size

       2609  bytes sent via SQL*Net to client

        392  bytes received via SQL*Net from client

          3  SQL*Net roundtrips to/from client

          0  sorts (memory)

          0  sorts (disk)

         23  rows processed          0  sorts (disk)

#####################################################################

使用Oracle的SQL Tuning Advisor固定运行计划--SQL_ID

----通过sql_id的方式  sql_id => 'a2h6pzvqncfvg',--想调优的sql_id

show serveroutput

set serveroutput on;



DECLARE  

    a_tuning_task VARCHAR2(30);  

  BEGIN  

    a_tuning_task := dbms_sqltune.create_tuning_task(sql_id => 'a2h6pzvqncfvg',task_name => 'tuning_test');    

    dbms_sqltune.execute_tuning_task(a_tuning_task);   

  END;  

  /

set long 1000

SELECT dbms_sqltune.report_tuning_task('tuning_test') FROM dual;

 

这里的输出中的sql_id是从v$sql查出。相应的是没有加hint的SQL。

假设SQL Tuning Advisor找到了理想的运行计划。下一步就是:Accept SQL Profile,接受这个SQL Profile。



## execute dbms_sqltune.accept_sql_profile(task_name =>'tuning_test' ,replace => TRUE,force_match=>true);

 完毕后验证语句:

set autotrace trace;

select a.*,b.owner from t1 a,t1 b where a.object_name like '%T1%' and a.object_id=b.object_id;

set autotrace off;

删除SQL语句:

exec dbms_sqltune.drop_tuning_task('tuning_test');  

 假设未找到理想的运行计划,则參考下一个方法。

##################################################################

使用Oracle的SQL Tuning Advisor固定运行计划--使用SQL_TEXT,參考下面:

DECLARE

 my_task_name VARCHAR2 (30);

 my_sqltext CLOB;

 BEGIN

 my_sqltext := 'select * from test where OBJECT_ID=15';  --想调优的sql

 my_task_name := dbms_sqltune.create_tuning_task (sql_text=> my_sqltext,

 --bind_list =>  'UNDO$',

 --user_name => 'SONG',

 --scope => 'COMPREHENSIVE',

 --time_limit => 60,

 task_name => 'sql_tuning_test'

 --description => 'Tuning Task'

 );

 END;

 /

 

 exec dbms_sqltune.execute_tuning_task('sql_tuning_test');   --运行调优的任务

  SELECT STATUS FROM USER_ADVISOR_TASKS WHERE task_name = 'sql_tuning_test'; --查看调优作业的状态

 SELECT DBMS_SQLTUNE.REPORT_TUNING_TASK('sql_tuning_test') FROM DUAL;--查看调优的建议

 exec dbms_sqltune.drop_tuning_task('sql_tuning_test');--删除任务

使用SQL Profile及SQL Tuning Advisor固定运行计划的更多相关文章

  1. Oracle 通过sql profile为sql语句加hint

    sql profile最大的优点是在不修改sql语句和会话执行环境的情况下去优化sql的执行效率,适合无法在应用程序中修改sql时.sql profile最常用方法大概是:--创建产生sql tuni ...

  2. Oracle 固定执行计划-使用SPM(Sql Plan Management)固定执行计划

    固定执行计划-使用SPM(Sql Plan Management)固定执行计划 转载自:http://www.lunar2013.com/2016/01/固定执行计划-使用spm%EF%BC%88sq ...

  3. SQL Tuning Advisor

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

  4. 如何使用coe_load_sql_profile.sql来固定sql profile

    SQLT工具包含一个脚本,名字是 coe_load_sql_profile.sql,下面以用户SCOTT的EMP表为例,说明如何使用该脚本固定sql profile. 1. SQL> -- 对e ...

  5. 为什么需要SQL Profile

    为什么需要SQL Profile Why oracle need SQL Profiles,how it work and what are SQL Profiles... 使用DBMS_XPLAN. ...

  6. SQL profile纵览(10g)

    第一篇:介绍         10g开始,查询优化器(Query optimizer)扩展成自动调整优化器(Automatic Tuning Optimizer).也就是扩展了功能.此时,我们就可以让 ...

  7. SQL Profile (总结4)--使用演示示例

    前提:sql profile工具的相关视图 dba_sql_profile 10g: sys.sqlprof$attr  &  sqlprof$ 11g: sys.sqlobj$data  & ...

  8. SQL Server如何固定执行计划

    SQL Server 其实从SQL Server 2005开始,也提供了类似ORACLE中固定执行计划的功能,只是好像很少人使用这个功能.当然在SQL Server中不叫"固定执行计划&qu ...

  9. 【故障处理141119】一次数据库不繁忙时一条sql语句2个运行计划导致业务超时的故障处理

    1,故障描写叙述: 一条select有两个运行计划.在sqlplus中运行选择好的运行计划.仅仅要40毫秒.而在程序中运行选择了差的运行计划,要1分23秒左右,导致前台业务超时报错. 2.故障解决: ...

随机推荐

  1. 第八届蓝桥杯省赛C/C++ A组第8题 包子凑数

    参考了http://blog.csdn.net/y1196645376/article/details/69718192 思路: 数论+完全背包. 实现: #include <iostream& ...

  2. web安全测试--XSS(跨站脚本)与CSRF

    XSS攻击原理 反射型 发出请求时,xss代码出现在URL中,作为输入提交到服务器端,服务器端解析后响应,xss代码随响应内容一起传回浏览器,最后浏览器解析执行xss代码.这个过程像一次反射,故叫反射 ...

  3. JPEG图像压缩出现资源不足问题的解决

    1,问题的提出 公司开发了一个图像压缩上传程序.采用Delphi语言实现.大致步骤如下: 1,上传前将文件打开装载到TJpegImage, 2,创建一个TBitmap组件,设置其大小,采用Stretc ...

  4. js中取整数的方法

    1.取整的方法 Math.floor( ) Math 对象的方法--取比当前数值小的最大整数(下取整). Math.ceil( ) Math对象的方法--取比当前数值大的最小整数(上取整). Math ...

  5. Android 将Bitmap对象保存为png图片文件

    输入:Bitmap对象.保存的路径.保存的文件名 注意路径的最后要带上  '/' 符号 private void saveBitmap(Bitmap bitmap,String path, Strin ...

  6. 腾讯云 LNMP+wordpress 搭建个人网站

    折腾了好几个小时才弄好(php nginx略知一二),其实一点都不难! 以此记录一下,献给首次搭建的朋友们!! 1)准备工作:(因为个人用的ubuntu16.04 LTS系统  所以这是debian版 ...

  7. Java Servlet JSP编程(一)

    最近想学学java编程,java现在的应用还是挺广泛的,有必要学习一下. # index.jsp <%@ page language="java" contentType=& ...

  8. 崩溃通常是指操作系统向正在运行的程序发送的信号-EXC_BAD_ACCESS是信号

    https://www.cnblogs.com/feng9exe/p/7243628.html

  9. ThinkPHP---AR模式

    [前言] 在之前学习框架时介绍过 (1)什么是框架? ①框架是一堆包含了常量.方法和类等代码集合: ②半成品应用,只包含了项目开发时的底层架构,并不包含业务逻辑: ③包含一些设计模式,例如单例模式,工 ...

  10. c++函数进阶

    c++扩展了c语言的函数功能.通过将incline关键字用于函数定义,并在首次调用该函数前提供其函数定义,可以使得c++编译器将该函数视为内联函数.也就是说,编译器不是让程序跳到独立的代码段,以执行函 ...