频 道 直 达 - 新闻 - 读书 - 培训 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 技术圈 - 博客 - BBS
51CTO.COM_中国领先的IT技术网站
找资料:

Oracle 11g:SQL性能分析器(三)(5)

作者: Jim Czuprynski/黄永兵 译 出处:51CTO.com 2008-04-21 15:30    砖    好    评论   进入论坛
阅读提示:Oracle数据库11g第一版(11gR1)新的SQL性能分析器许诺较大地减轻了忙碌的Oracle DBA的工作量,因为它提供了一个精确地评估前后性能变化的完整的数据库工作负载的方法。
列表一

/*
|| Oracle 11g SQL Performance Analyzer Listing 1
||
|| Demonstrates Oracle 11g SQL Performance Analyzer (SPA) basic techniques,
|| including:
|| - Setup and configuration of required sample database objects
|| - Creation of SQL Tuning Sets for "before" and "after" image comparson
|| - Execution of SQL Performance Analyzer "before" test image
|| - Execution of SQL Performance Analyzer "after" test image
|| - Execution of SQL Performance Analyzer comparison reports
||
|| Author: Jim Czuprynski
||
|| Usage Notes:
|| These examples are provided to demonstrate various features of Oracle 11g
|| SQL Performance Analyzer features, and they should be carefully proofread
|| before executing them against any existing Oracle database(s) to avoid
|| potential damage!
*/


/*
|| Listing 1.1:
|| Create a new table (SH.SALES_AGENTS) and corresponding objects for
|| simulated performance tuning
*/

DROP TABLESPACE lmt_data INCLUDING CONTENTS AND DATAFILES;
CREATE SMALLFILE TABLESPACE lmt_data
DATAFILE '/u01/app/oracle/oradata/orcl/lmt_data01.dbf'
SIZE 60M
AUTOEXTEND ON
LOGGING
EXTENT MANAGEMENT LOCAL
SEGMENT SPACE MANAGEMENT AUTO;

DROP TABLESPACE lmt_idx INCLUDING CONTENTS AND DATAFILES;
CREATE SMALLFILE TABLESPACE lmt_idx
DATAFILE '/u01/app/oracle/oradata/orcl/lmt_idx01.dbf'
SIZE 60M
AUTOEXTEND ON
LOGGING
EXTENT MANAGEMENT LOCAL
SEGMENT SPACE MANAGEMENT AUTO;

DROP TABLE sh.sales_agents PURGE;
CREATE TABLE sh.sales_agents(
salesperson_id      NUMBER(10)     NOT NULL
,last_name           VARCHAR2(32)   NOT NULL
,first_name          VARCHAR2(32)   NOT NULL
,address_line_1      VARCHAR2(40)  
,address_line_2      VARCHAR2(40)  
,address_line_3      VARCHAR2(40)   NOT NULL
,city                VARCHAR2(40)   NOT NULL
,locale              VARCHAR2(40)
,state               VARCHAR2(2)   
,postal_code         VARCHAR2(10)  
,country             VARCHAR2(32)  
)
TABLESPACE lmt_data
STORAGE (INITIAL 1M)
;

DROP INDEX sh.sales_agents_pk_idx;
CREATE UNIQUE INDEX sh.sales_agents_pk_idx
ON sh.sales_agents (salesperson_id)
TABLESPACE lmt_idx
STORAGE (INITIAL 1M)
;

ALTER TABLE sh.sales_agents
ADD CONSTRAINT salesperson_pk
PRIMARY KEY (salesperson_id)
;

/*
|| Initial Data Load
*/

@LoadSalesAgents.sql;

/*
|| Index Creation and Statistics Gathering
*/

-----
-- Create alternate indexes for reporting
-----
DROP INDEX sh.sales_agents_la_idx;
CREATE INDEX sh.sales_agents_la_idx
ON sh.sales_agents (last_name ASC)
TABLESPACE lmt_idx
STORAGE (INITIAL 1M)
;

DROP INDEX sh.sales_agents_sa_idx;
CREATE INDEX sh.sales_agents_sa_idx
ON sh.sales_agents (state ASC)
TABLESPACE lmt_idx
STORAGE (INITIAL 1M)
;

DROP INDEX sh.sales_agents_lafa_idx;
CREATE INDEX sh.sales_agents_lafa_idx
ON sh.sales_agents (last_name ASC, first_name ASC)
TABLESPACE lmt_idx
STORAGE (INITIAL 1M)
;

DROP INDEX sh.sales_agents_saca_idx;
CREATE INDEX sh.sales_agents_saca_idx
ON sh.sales_agents (state ASC, city ASC)
TABLESPACE lmt_idx
STORAGE (INITIAL 1M)
;

-----
-- Gather statistics on table and its indexes, and
-- then lock them to prevent unexpected recalculation
-- during nightly statistics regathering job
-----
BEGIN
DBMS_STATS.GATHER_TABLE_STATS(
ownname => 'SH'
,tabname => 'SALES_AGENTS'
,cascade => TRUE
,force => TRUE
);
END;
/

/*
|| Listing 1.2: Load Generation
|| While the SQL Tuning Set task in Listing 1.x is "watching,"
|| generate a load on the database that  can be captured into a
|| SQL Tuning Set for later analysis with the SQL Performance Analyzer (SPA)
*/

CONNECT ldgn/ldgn;
SET ECHO ON
SET TIMING ON

-----
-- Scenario 1.0:
-- Let the Cost-Based Optimizer choose the best query plan
-----
SELECT /*LDGN_1.0*/
SA.last_name
,SA.first_name
,SA.city
,SA.state
,SA.postal_code
FROM
sh.sales_agents SA
WHERE ((SA.city = 'Chicago' AND SA.state = 'IL') OR SA.state = 'IN')
OR SA.last_name LIKE 'Crystal%'
;

-----
-- Scenario 1.1:
-- Force the query to ignore all indexes
-----
SELECT /*+ NO_INDEX(SA) LDGN_1.1*/
SA.last_name
,SA.first_name
,SA.city
,SA.state
,SA.postal_code
FROM
sh.sales_agents SA
WHERE ((SA.city = 'Chicago' AND SA.state = 'IL') OR SA.state = 'IN')
OR SA.last_name LIKE 'Crystal%'
;

-----
-- Scenario 1.2:
-- Force the query to ignore at least one of the obvious
-- "best choice" indexes
-----
SELECT /*+ NO_INDEX(SA sales_agents_la_idx) LDGN_1.2*/
SA.last_name
,SA.first_name
,SA.city
,SA.state
,SA.postal_code
FROM
sh.sales_agents SA
WHERE ((SA.city = 'Chicago' AND SA.state = 'IL') OR SA.state = 'IN')
OR SA.last_name LIKE 'Crystal%'
;

-----
-- Scenario 1.3:
-- Force the query to use a wrong index
-----
SELECT /*+INDEX(SA sales_agents_pk_idx) LDGN_1.3*/
SA.last_name
,SA.first_name
,SA.city
,SA.state
,SA.postal_code
FROM
sh.sales_agents SA
WHERE ((SA.city = 'Chicago' AND SA.state = 'IL') OR SA.state = 'IN')
OR SA.last_name LIKE 'Crystal%'
;

-----
-- Scenario 2.0:
-- Let the Cost-Based Optimizer choose the best query plan
-----
SELECT /*LDGN_2.0*/
SA.state
,COUNT(SA.city) tot_cities
FROM
sh.sales_agents SA
WHERE (SA.last_name,SA.first_name) IN (('Wells','Billy'),('Alexander','Kirk'))
GROUP BY SA.state
ORDER BY SA.state;
;

-----
-- Scenario 2.1:
-- Force the query to use a poorer index (SALES_AGENTS_SACA_IDX)
-- even though a better index (SALES_AGENTS_LAFA_IDX) exists
-----
SELECT /*+INDEX(SA, SALES_AGENTS_SACA_IDX) LDGN_2.1*/
SA.state
,COUNT(SA.city) tot_cities
FROM
sh.sales_agents SA
WHERE (SA.last_name,SA.first_name) IN (('Wells','Billy'),('Alexander','Kirk'))
GROUP BY SA.state
ORDER BY SA.state;
;

-----
-- Scenario 3.0:
-- Let the Cost-Based Optimizer choose the best query plan
-----
SELECT /*LDGN_3.0*/
SA.state
,SA.city
,COUNT(SA.last_name) namecnt
,MIN(SA.last_name) min_lname
,MAX(SA.last_name) max_lname
,MIN(SA.first_name) min_fname
,MAX(SA.first_name) max_fname
FROM
sh.sales_agents SA
WHERE (SA.city,SA.state) IN (
('Milpitas','CA')
,('Schaumburg','IL')
,('El Paso','TX')
,('Oshkosh','WI'))
GROUP BY SA.state, SA.city
ORDER BY SA.state, SA.city;
;

-----
-- Scenario 3.1:
-- Force the query to use a poorer index (SALES_AGENTS_LAFA_IDX)
-- even though a better index (SALES_AGENTS_SACA_IDX) exists
-----
SELECT /*+INDEX(SA, SALES_AGENTS_LAFA_IDX) LDGN_3.1*/
SA.state
,SA.city
,COUNT(SA.last_name) namecnt
,MIN(SA.last_name) min_lname
,MAX(SA.last_name) max_lname
,MIN(SA.first_name) min_fname
,MAX(SA.first_name) max_fname
FROM
sh.sales_agents SA
WHERE (SA.city,SA.state) IN (
('Milpitas','CA')
,('Schaumburg','IL')
,('El Paso','TX')
,('Oshkosh','WI'))
GROUP BY SA.state, SA.city
ORDER BY SA.state, SA.city;
;

SET ECHO OFF
SET TIMING OFF
DISCONNECT;

/*
|| Listing 1.3: SQL Tuning Set Creation
|| Create and prepare to populate a SQL Tuning Set (STS)
|| for selected SQL statements. Note that this STS will capture
|| all SQL statements which are executed by the LDGN user account
|| within a 5-minute period, and Oracle will check every 5 seconds
|| for any new statements
*/

BEGIN
DBMS_SQLTUNE.CREATE_SQLSET(
sqlset_name => 'STS_SPA_100'
);
DBMS_SQLTUNE.CAPTURE_CURSOR_CACHE_SQLSET(                        
sqlset_name => 'STS_SPA_100'
,basic_filter=> q'#sql_text LIKE '%LDGN_%' AND parsing_schema_name = 'LDGN'#'
,time_limit  => 300
,repeat_interval => 5
);
END;
/

/*
|| Listing 1.4: Generate SQL Performance Analysis Task
|| In the following steps:
|| 1.) A new SQL Performance Analysis (SPA) task is generated
|| 2.) The SPA task is executed in test execution mode to
||     produce a "before" image
*/
-----
-- Create a SQL Performance Analysis Task
-----
DECLARE
spa_task_name   VARCHAR2(64);
BEGIN
spa_task_name :=
DBMS_SQLPA.CREATE_ANALYSIS_TASK(
sqlset_name => 'STS_SPA_100'
,basic_filter => NULL
,order_by => NULL
,top_sql => NULL
,description => 'Comparison of LDGN-executed SQL statements'
,sqlset_owner => 'SYS'
);
END;
/

-----
-- Execute the SQL Performance Analysis Task to capture the "before"
-- image of the SQL Tuning Set's performance
-----
BEGIN
DBMS_SQLPA.EXECUTE_ANALYSIS_TASK(
task_name => 'TASK_69'
,execution_type => 'test execute'
,execution_name => 'SQR_100_BEFORE'
,execution_desc => 'SPA Before Image'
,execution_params => DBMS_ADVISOR.ARGLIST('TEST_EXECUTE','FULL')
);
END;
/

/*
|| Listing 1.5: Change the Database Environment
|| Drop some of the indexes that were utilized heavily
|| by the previously-run SQL statements, and then regather
|| optimizer statistics
*/

DROP INDEX sh.sales_agents_la_idx;
DROP INDEX sh.sales_agents_saca_idx;
BEGIN
DBMS_STATS.GATHER_TABLE_STATS(
ownname => 'SH'
,tabname => 'SALES_AGENTS'
,cascade => TRUE
,force => TRUE
);
END;
/

/*
|| Listing 1.6: Generate An "After" Performance Image
|| The existing the SQL Performance Analysis Task is re-executed
|| to capture the "after" image of the SQL Tuning Set's performance
*/

BEGIN
DBMS_SQLPA.EXECUTE_ANALYSIS_TASK(
task_name => 'TASK_69'
,execution_type => 'test execute'
,execution_name => 'SQR_100_AFTER'
,execution_desc => 'SPA After Image'
,execution_params => DBMS_ADVISOR.ARGLIST('TEST_EXECUTE','FULL')
);
END;
/

/*
|| Listing 1.7: Compare Before vs. After Performance
*/

BEGIN
DBMS_SQLPA.EXECUTE_ANALYSIS_TASK(
task_name => 'TASK_69'
,execution_type => 'compare performance'
,execution_name => 'SPA_110_PC'
,execution_desc => 'SPA 110 Performance Comparison'
,execution_params =>
DBMS_ADVISOR.ARGLIST(
'EXECUTION_NAME1','SQR_BEFORE_110'
,'EXECUTION_NAME2','SQR_AFTER_110'
,'COMPARISON_METRIC','ELAPSED_TIME'
)
);
END;
/

/*
|| Listing 1.8: Generate Comparison Report
|| Now that the comparison is completed, generate the "delta" report
|| using DBMS_SQLPA.REPORT_ANALYSIS_TASK
*/

SET PAGESIZE 0
SET LINESIZE 1000
SET SERVEROUTPUT ON SIZE UNLIMITED
DECLARE
tLOB CLOB;
BEGIN
SELECT DBMS_SQLPA.REPORT_ANALYSIS_TASK('TASK_69')
INTO tLOB
FROM DUAL;
DBMS_OUTPUT.PUT_LINE(tLOB);
END;
/


共7页: 上一页 [1] [2] [3] [4] 5 [6] [7] 下一页
【内容导航】
 第 1 页:准备工作  第 2 页:情景#1
 第 3 页:情景#2  第 4 页:情景#3
 第 5 页:列表一  第 6 页:列表二
 第 7 页:列表三
专题
Sun以10亿美元并购开源数据库厂商MySQL
甲骨文Oracle 11g正式发布
Oracle数据库开发之PL/SQL基础应用
Oracle较真SAP-商业管理软件之战一触即发
Oracle数据库开发基础教程
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 领 先 的 IT 技 术 网 站 ·
技 术 成 就 梦 想
·SQL Server入门到精通 (查看101958次)
·SQL Server 2008/2005全解 (查看84095次)
·Oracle数据库开发指南 (查看43955次)
·Oracle SQL 内置函数大全 (查看40382次)
·MySQL数据库备份 (查看38747次)
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
见证中国网络安全二十年
见证中国网络安全..
勇闯IT培训黑色围城
勇闯IT培训黑色围..
技术人求职简历完备手册
技术人求职简历完..
· 技术人求职简历完备手册
· 华为员工自杀频频拷问..
· 视频访谈:网管员如何踏..
· 首届中国IT工程师生态..
· 思科全球CEO钱伯斯第七..
· 北漂技术人90天求职纪实
· 2007年互联网大会
· 龙芯要做中国的“奔腾”
· IPv6协议--拓展网络无..
· 国际文档格式标准开战
· 微软出价446亿美元收购..
· 贝恩资本携手华为22亿..
· Linux——从菜鸟到高手
· SOA 面向服务架构
· 2008年4月全国计算机等..
· 微软Forefront企业安全..
ARP攻击防范与解决方案
ARP攻击防范与解..
iSCSI应用与发展
iSCSI应用与发展
SQL Server 2008/2005全解
SQL Server 2008/..
· SQL Server 2008/2005..
· SOA 面向服务架构
· SQL Server 2008/2005..
· iSCSI应用与发展
· RAID——磁盘阵列基础
· 中间件应用技术专题
· SQL Server入门到精通
· 病毒查杀专题
· 国际文档格式标准开战
· 路由器设置与口令恢复
· Linux防火墙
· 打造安全服务器
· SOA 面向服务架构
· PHP开发应用手册
· ADSL应用面面俱到
· 入侵防护系统(IPS)初探
ARP攻击防范与解决方案
ARP攻击防范与解..
SQL Server 2008/2005全解
SQL Server 2008/..
iSCSI应用与发展
iSCSI应用与发展
· iSCSI应用与发展
· 中间件应用技术专题
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· iSCSI应用与发展
· RAID——磁盘阵列基础
· 病毒查杀专题
· 路由器设置与口令恢复
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· ADSL应用面面俱到
· ADSL应用面面俱到
· PHP开发应用手册
· 中间件应用技术专题
· Linux防火墙