SQL Tuning 基础概述08 - SQL Tuning Advisor

SQL调优顾问 SQL Tuning Advisor的使用案例:

1.构建测试表T

SQL> conn zjy/zjy
Connected.
SQL> create table t as select * from dba_objects;

Table created.
SQL> select count(*) from t;

COUNT(*)
----------
653500

2.定义调整任务

对“select owner, object_id, object_name from t where object_id=200000”这个sql定义调整任务:

declare 
tune_task_name varchar2(30);
bad_sql_stmt clob;
begin
 bad_sql_stmt := '';
 tune_task_name := dbms_sqltune.create_tuning_task
 (sql_text => bad_sql_stmt,
 user_name => 'ZJY',
 scope => 'COMPREHENSIVE',
 time_limit => 3600,
 task_name => 'zjy_sql_tuning_task',
 description => 'sql_tuning_advisor for this sql'
 ); 
end;
/

 

SQL> declare 
2 tune_task_name varchar2(30);
3 bad_sql_stmt clob;
4 begin
5 bad_sql_stmt := 'select owner, object_id, object_name from t where object_id=200000';
6 tune_task_name := dbms_sqltune.create_tuning_task
7 (sql_text => bad_sql_stmt,
8 user_name => 'ZJY',
9 scope => 'COMPREHENSIVE',
10 time_limit => 3600,
11 task_name => 'zjy_sql_tuning_task',
12 description => 'sql_tuning_advisor for this sql'
13 ); 
14 end;
15 /

PL/SQL procedure successfully completed.

3.修改调整任务参数

可以修改调整任务的一些参数,比如:

SQL> begin
2 dbms_sqltune.set_tuning_task_parameter
3 (task_name => 'zjy_sql_tuning_task',
4 parameter => 'TIME_LIMIT', value => 1800
5 );
6 end;
7 /

PL/SQL procedure successfully completed.

4.执行调整任务

开始执行调整任务:

begin
 dbms_sqltune.execute_tuning_task
 (task_name => 'zjy_sql_tuning_task');
end;
/

 

SQL> begin
2 dbms_sqltune.execute_tuning_task
3 (task_name => 'zjy_sql_tuning_task');
4 end;
5 /

PL/SQL procedure successfully completed.

5.监控调整任务

监控调整任务的执行状态:

select task_name, status, sofar, totalwork
 from dba_advisor_tasks
 join v$advisor_progress using(task_id)
 where task_name = 'zjy_sql_tuning_task';

 

SQL> select task_name, status, sofar, totalwork
2 from dba_advisor_tasks
3 join v$advisor_progress using(task_id)
4 where task_name = 'zjy_sql_tuning_task';

TASK_NAME STATUS SOFAR TOTALWORK
------------------------------ ----------- ---------- ----------
zjy_sql_tuning_task COMPLETED 1 1

6.查看调整任务建议

查看调整任务最终给出的建议:

SQL> select dbms_sqltune.report_tuning_task('zjy_sql_tuning_task') from dual;

DBMS_SQLTUNE.REPORT_TUNING_TASK('ZJY_SQL_TUNING_TASK')
-------------------------------------------------------------------------------
GENERAL INFORMATION SECTION
-------------------------------------------------------------------------------
Tuning Task Name : zjy_sql_tuning_task
Tuning Task Owner : ZJY
Workload Type : Single SQL Statement
Scope : COMPREHENSIVE
Time Limit(seconds): 1800
Completion Status : COMPLETED
Started at : 01/23/2015 14:58:40
Completed at : 01/23/2015 14:58:58

-------------------------------------------------------------------------------
Schema Name: ZJY
SQL ID : dmw0nx6g0b6h7
SQL Text : select owner, object_id, object_name from t where
object_id=200000

-------------------------------------------------------------------------------
FINDINGS SECTION (2 findings)
-------------------------------------------------------------------------------

1- Statistics Finding
---------------------
尚未分析表 "ZJY"."T"。

Recommendation
--------------
- 考虑收集此表的优化程序统计信息。
execute dbms_stats.gather_table_stats(ownname => 'ZJY', tabname => 'T',
estimate_percent => DBMS_STATS.AUTO_SAMPLE_SIZE, method_opt =>
'FOR ALL COLUMNS SIZE AUTO');

Rationale
---------
为了选择好的执行计划, 优化程序需要此表的最新统计信息。

2- Index Finding (see explain plans section below)
--------------------------------------------------
通过创建一个或多个索引可以改进此语句的执行计划。

Recommendation (estimated benefit: 99.86%)
------------------------------------------
- 考虑运行可以改进物理方案设计的访问指导或者创建推荐的索引。
create index ZJY.IDX$$_3EC90001 on ZJY.T("OBJECT_ID","OWNER","OBJECT_NAME")
;

Rationale
---------
创建推荐的索引可以显著地改进此语句的执行计划。但是, 使用典型的 SQL 工作量运行 "访问指导"
可能比单个语句更可取。通过这种方法可以获得全面的索引建议案, 包括计算索引维护的开销和附加的空间消耗。

-------------------------------------------------------------------------------
EXPLAIN PLANS SECTION
-------------------------------------------------------------------------------

1- Original
-----------
Plan hash value: 1601196873

--------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 124 | 11904 | 3059 (1)| 00:00:37 |
|* 1 | TABLE ACCESS FULL| T | 124 | 11904 | 3059 (1)| 00:00:37 |
--------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

1 - filter("OBJECT_ID"=200000)

2- Using New Indices
--------------------
Plan hash value: 3141638344

-----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 96 | 4 (0)| 00:00:01 |
|* 1 | INDEX RANGE SCAN| IDX$$_3EC90001 | 1 | 96 | 4 (0)| 00:00:01 |
-----------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

1 - access("OBJECT_ID"=200000)

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

7.删除调整任务

删除调整任务:

SQL> exec dbms_sqltune.drop_tuning_task('zjy_sql_tuning_task') ;

PL/SQL procedure successfully completed.

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于C++&OPENCV 的全景图像拼接 C++是一种广泛使用的编程语言,它是由Bjarne Stroustrup于1979年在新泽西州美利山贝尔实验室开始设计开发的。C++是C语言的扩展,旨在提供更强大的编程能力,包括面向对象编程和泛型编程的支持。C++支持数据封装、继承和多态等面向对象编程的特性和泛型编程的模板,以及丰富的标准库,提供了大量的数据结构和算法,极大地提高了开发效率。12 C++是一种静态类型的、编译式的、通用的、大小写敏感的编程语言,它综合了高级语言和低级语言的特点。C++的语法与C语言非常相似,但增加了许多面向对象编程的特性,如类、对象、封装、继承和多态等。这使得C++既保持了C语言的低级特性,如直接访问硬件的能力,又提供了高级语言的特性,如数据封装和代码重用。13 C++的应用领域非常广泛,包括但不限于教育、系统开发、游戏开发、嵌入式系统、工业和商业应用、科研和高性能计算等领域。在教育领域,C++因其结构化和面向对象的特性,常被选为计算机科学和工程专业的入门编程语言。在系统开发领域,C++因其高效性和灵活性,经常被作为开发语言。游戏开发领域中,C++由于其高效性和广泛应用,在开发高性能游戏和游戏引擎中扮演着重要角色。在嵌入式系统领域,C++的高效和灵活性使其成为理想选择。此外,C++还广泛应用于桌面应用、Web浏览器、操作系统、编译器、媒体应用程序、数据库引擎、医疗工程和机器人等领域。16 学习C++的关键是理解其核心概念和编程风格,而不是过于深入技术细节。C++支持多种编程风格,每种风格都能有效地保证运行时间效率和空间效率。因此,无论是初学者还是经验丰富的程序员,都可以通过C++来设计和实现新系统或维护旧系统。3

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值