oracle自动sql优化

oracle的优化器运行在下面的2个模式下:
1常规模式
优化器编译sql,生成执行计划,这个耗时一般很短
2优化模式
优化器进行额外的分析看是否能提供更好的执行计划,优化器的输出不是执行计划,而是一系列动作,在这个模式下的优化器就是Automatic Tuning Optimizer.这个阶段花费的时间一般都很长,只是对那些复杂,高负载的语句有意义。

Automatic Database Diagnostic Monitor (ADDM) 来标记那些语句是能优化的,自动化sql优化功能也会标识有问题的sql,在系统维护窗口中实施优化建议来作为一个自动化的维护任务。
看上去oracle背后智能的调整了很多东西。
自动优化器进行下面的一些操作。
1统计信息分析
2sql 探测
3访问路径分析
4sql结构分析
5可选计划分析

自动优化器会检查每个对象缺失或过期的统计信息。产生2中类型的输出:
1在自动优化器统计收集被关闭的情况下,提示需要收集过期的统计信息。
自动维护任务会在维护窗口运行维护任务。默认,自动统计信息是被开启的,在每个维护窗口运行
启动自动统计信息收集
BEGIN
DBMS_AUTO_TASK_ADMIN.ENABLE(
client_name => ‘auto optimizer stats collection’
, operation => NULL
, window_name => NULL
);
END;
/
关闭
BEGIN
DBMS_AUTO_TASK_ADMIN.DISABLE(
client_name => ‘auto optimizer stats collection’
, operation => NULL
, window_name => NULL
);
END;
/
2补充没有统计信息的对象的统计信息,调整过期统计信息对象的因子。

sql profile是一个sql语句的辅助信息的集合。优化器是结合sql profile和坏境的信息一起生成了执行计划的。

你可以跟sql plan管理或独自使用sql profile,如果你使用sql计划管理,那么选取的计划一定是被计划基线启用的。
sql profile有下面的一些好处:
1与hint或存储概要不同,profile不会绑定到具体的计划或子计划上。
2不需要修改源码。
使用DBMS_SQLTUNE.ACCEPT_SQL_PROFILE 来接受sql profile的时候,这个步骤在数据库中创建并存储sql profile

接受profile
DECLARE
my_sqlprofile_name VARCHAR2(30);
BEGIN
my_sqlprofile_name := DBMS_SQLTUNE.ACCEPT_SQL_PROFILE (
task_name => ‘my_sql_tuning_task’,
name => ‘my_sql_profile’,
profile_type => DBMS_SQLTUNE.PX_PROFILE,
force_match => TRUE );
END;
/
可以通过 DBA_SQL_PROFILES这个视图来查看啊profile的信息。
修改profile,下面的例子中在sql编译的期间禁用profile
BEGIN
DBMS_SQLTUNE.ALTER_SQL_PROFILE(
name => ‘my_sql_profile’,
attribute_name => ‘STATUS’,
value => ‘DISABLED’);
END;
/

传输sql profile
To transport a SQL profile:

Use the CREATE_STGTAB_SQLPROF procedure to create a staging table where the SQL profiles will be exported.

The following example creates my_staging_table in the DBA1 schema:

BEGIN
DBMS_SQLTUNE.create_stgtab_sqlprof(
table_name => ‘my_staging_table’,
schema_name => ‘DBA1’ );
END;
/
Use the PACK_STGTAB_SQLPROF procedure to export SQL profiles into the staging table.

The following example populates dba1.my_staging_table with the SQL profile my_profile:

BEGIN
DBMS_SQLTUNE.pack_stgtab_sqlprof(
profile_name => ‘my_profile’,
staging_table_name => ‘my_staging_table’,
staging_schema_owner => ‘dba1’ );
END;
/
Move the staging table to the database where the SQL profiles will be imported using the mechanism of choice (such as Oracle Data Pump or database link).

On the database where the SQL profiles will be imported, use the UNPACK_STGTAB_SQLPROF procedure to import SQL profiles from the staging table.

The following example shows how to import SQL profiles contained in the staging table:

BEGIN
DBMS_SQLTUNE.UNPACK_STGTAB_SQLPROF(
replace => TRUE,
staging_table_name => ‘my_staging_table’);
END;
/

sql优化信息视图:
DBA_SQLTUNE_STATISTICS, DBA_SQLTUNE_BINDS, and DBA_SQLTUNE_PLANS
sql优化集视图DBA_SQLSET, DBA_SQLSET_BINDS, DBA_SQLSET_STATEMENTS, and DBA_SQLSET_REFERENCES

sql优化顾问将一个或多个sql作为输入,调用自动优化器来进行sql优化,输出是建议或推荐。推荐是对象上的统计信息收集,新索引创建,重新组织sql,或创建sql profile。
数据库可以自动的在系统维护窗口使用sql优化顾问优化sql,这个时候叫自动sql优化顾问。
oracle会自动的将awr中的负载重的sql标记成候选者,来运行sql优化顾问,下面是流程图
这里写图片描述

启用自动sql优化
BEGIN
DBMS_AUTO_TASK_ADMIN.ENABLE(
client_name => ‘sql tuning advisor’
, operation => NULL
, window_name => NULL
);
END;
/
关闭sql自动优化
BEGIN
DBMS_AUTO_TASK_ADMIN.DISABLE(
client_name => ‘sql tuning advisor’
, operation => NULL
, window_name => NULL
);
END;
/

You can pass a specific window name using the window_name parameter to enable or disable the task in certain maintenance windows only.

配置sql自动优化选项,下面是自动接收sql优化顾问产生的sql profle
BEGIN
DBMS_AUTO_SQLTUNE.SET_AUTO_TUNING_TASK_PARAMETER(
parameter => ‘ACCEPT_SQL_PROFILES’, value => ‘TRUE’);
END;
/

查看自动sql优化报告
下面的例子生成了一个txt报告
VARIABLE my_rept CLOB;
BEGIN
:my_rept :=DBMS_AUTO_SQLTUNE.REPORT_AUTO_TUNING_TASK(
begin_exec => NULL,
end_exec => NULL,
type => ‘TEXT’,
level => ‘TYPICAL’,
section => ‘ALL’,
object_id => NULL,
result_limit => NULL);
END;
/

PRINT :my_rept

你可以对一个或多个sql语句单独使用sql优化顾问,要条有多个sql,你需要创建一个sql优化集合,
sql优化顾问的输入可以是下面的几种:
1addm
2awr
3共享sql区
4sql优化集合
使用sql优化顾问的步骤:
Create a SQL tuning set (if tuning multiple SQL statements)

Create a SQL tuning task

Execute a SQL tuning task

Display the results of a SQL tuning task

Implement recommendations as appropriate

创建任务:
DECLARE
my_task_name VARCHAR2(30);
my_sqltext CLOB;
BEGIN
my_sqltext := ‘SELECT /+ ORDERED / * ’ ||
‘FROM employees e, locations l, departments d ’ ||
‘WHERE e.department_id = d.department_id AND ’ ||
‘l.location_id = d.location_id AND ’ ||
‘e.employee_id < :bnd’;

my_task_name := DBMS_SQLTUNE.CREATE_TUNING_TASK(
sql_text => my_sqltext,
bind_list => sql_binds(anydata.ConvertNumber(100)),
user_name => ‘HR’,
scope => ‘COMPREHENSIVE’,
time_limit => 60,
task_name => ‘my_sql_tuning_task’,
description => ‘Task to tune a query on a specified employee’);
END;
/
查看用户下的任务
SELECT TASK_NAME FROM DBA_ADVISOR_LOG WHERE OWNER = ‘HR’;
配置一个任务
BEGIN
DBMS_SQLTUNE.SET_TUNING_TASK_PARAMETER(
task_name => ‘my_sql_tuning_task’,
parameter => ‘TIME_LIMIT’, value => 300);
END;
/

执行任务:
BEGIN
DBMS_SQLTUNE.EXECUTE_TUNING_TASK( task_name => ‘my_sql_tuning_task’ );
END;
/

查看任务状态
SELECT status
FROM USER_ADVISOR_TASKS
WHERE task_name = ‘my_sql_tuning_task’;

检查sql优化顾问的进程:
SELECT SOFAR, TOTALWORK
FROM V$ADVISOR_PROGRESS
WHERE USER_NAME = ‘HR’ AND TASK_NAME = ‘my_sql_tuning_task’;

显示优化任务的结果:
SET LONG 1000
SET LONGCHUNKSIZE 1000
SET LINESIZE 100
SELECT DBMS_SQLTUNE.REPORT_TUNING_TASK( ‘my_sql_tuning_task’)
FROM DUAL;

更优更快 人工智能自动SQL优化----------http://www.sina.com.cn 2001/12/12 17:48 中国电脑教育报文/SQL爱好者  所谓SQL,就是指Structured Query Language(结构化查询语言),它是目前使用最广泛的数据库语言,用来和数据库打交道,从数据库中得到用户需要的数据。但是要想熟练使用SQL语句,也不是一件简单的事,有些语句使用起来也比较麻烦。如果我们对SQL语句进行优化,那么用户使用起来 就会方便许多。  简单来说,SQL语句的优化就是将性能低下的SQL语句转换成达到同样目的的性能优异的SQL语句。人工智能自动SQL优化就是使用人工智能技术,自动对SQL语句进行重写,找到性能最好的等效SQL语句。  人工智能自动SQL 优化  随着人工智能技术的发展和在数据库优化领域应用的深入,在20世纪90年代末终于出现了突破性的进展——人工智能自动SQL优化。目前在商用数据库领域LECCO TechnologyLimited(灵高公司)拥有该技术并提供使用该技术的自动优化产品——LECCO SQL Expert,其支持Oracle、Sybase、MS SQLServer和IBMDB2数据库平台。该产品针对数据库应用的开发和维护阶段提供了几个特别的模块:SQL语法优化器、PL/SQL集成化开发调试环境(IDE)、扫描器、数据库监视器等。图1 人工智能自动SQL优化示意图  其核心模块之一“SQL语法优化器”的工作原理大致如下(如图1):  一条源SQL语句输入→“人工智能反馈式搜索引擎”对输入的SQL语句结合检测到的数据库结构和索引进行重写,产生N条等效的SQL语句输出→产生的N条等效SQL语句再送入“人工智能反馈式搜索引擎”进行重写,直至无法产生新的输出或搜索限额满→对 输出的SQL语句进行过滤,选出具有不同执行计划的SQL语句(即不同的执行效率)→对得到的SQL语句进行批量测试,找出性能最好的SQL语句。图2 优化前的SQL语句  自动优化实例  假设我们从源代码中抽取出这条SQL语句(如图2):  SELECTCOUNT(*)FROMEMPLOY-EE WHEREEXISTS(SELECT'X'FROM DEPARTMENTswheresEMP_DEPT=DPT_IDAND DPT_NAME LIKE'AC%')AND EMP_IDIN(SELECT SAL_EMP_IDFROM EMP_SAL_HISTB WHERESAL_SALARY>70000)   按“优化”按钮后,经过十几秒,SQL Expert就完成了优化的过程,从优化细节中可以看到,它在十几秒的时间内重写产生了2267条等价的SQL语句,其中136条SQL语句有不同的执行计划(如图3)。图3 优化结果  接下来我们可以对自动重写产生的136条具有不同执行计划的SQL语句进行批运行测试,以选出性能最佳的等效SQL语句。按下“批运行”按钮,在“终止条件”页选择“最佳运行时间SQL语句”(如图4),按“确定”。图4 测试条件  经过几分钟的测试运行后,我们可以发现SQL124的运行时间和反应时间最短。运行速度约有22.75倍的提升(源SQL语句运行时间为2.73秒,SQL124运行时间为0.12秒,如图5)。图5 测试结果  我们把SQL124放入源代码中,结束一条SQL语句的优化工作。从上例可以看到,LECCO SQL Expert的自动重写技术使原来需要几小时才能完成的SQL语句的优化工作,缩减到几分钟之内就可以完成。数据库管理员和开发人员可以从繁重的SQL语句优化工作中解脱出来。  边做边学式训练  LECCO SQL Expert不仅能够找到最佳的SQL语句,而且提供的“边做边学式训练”还能够教会开发人员和数据库管理员如何写出性能最好的SQL语句。LECCO SQL Expert的“SQL比较器”可以标明源SQL和待选SQL之间的不同之处。LECCO SQL Expert详尽的上下文敏感帮助系统可以指出执行计划的深层含义。图6 源语句与SQL124的比较  以上面优化的结果为例,为了查看源SQL语句和SQL124在写法上的不同,我们可以按下“比较器”按钮,对SQL124和源SQL语句进行比较。如果选择“双向比较”复选框,“SQL比较器”可以将两条互相间的不同之处以蓝色表示。当然,你也可以从 源语句和重写后的SQL语句中任选两条进行比较(如图6)。  从比较的结果可以看到,重写得到的SQL124把第一个Exists改写成了In;在字段DPT_ID上进行了合并空字符串的操作以诱导数据库先执行子查询中的(SELECTDPT_ID||'FROMDEPART-MENTWH
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值