5 Copyright © 2007, Oracle. All rights reserved. Implementing the Performance Improvements.

Slides:



Advertisements
Similar presentations
13 Copyright © 2005, Oracle. All rights reserved. Monitoring and Improving Performance.
Advertisements

Copyright © 200\8 Quest Software High Performance PL/SQL Guy Harrison Chief Architect, Database Solutions.
15 Copyright © 2004, Oracle. All rights reserved. Monitoring and Managing Memory.
3 Copyright © 2004, Oracle. All rights reserved. Creating Packages.
A Guide to Oracle9i1 Advanced SQL And PL/SQL Topics Chapter 9.
10 Copyright © 2009, Oracle. All rights reserved. Managing Undo Data.
PL/SQL Bulk Collections in Oracle 9i and 10g Kent Crotty Burleson Consulting October 13, 2006.
23 Copyright © 2004, Oracle. All rights reserved. Sharing Objects and Code.
11g New Features for PL/SQL Developers Tim Hall Oracle ACE Director Oracle ACE of the Year 2006 OCP DBA (7, 8, 8i, 9i, 10g,
Cursor and Exception Handling By Nidhi Bhatnagar.
2 Copyright © 2006, Oracle. All rights reserved. Performance Tuning: Overview.
1 Oracle Database 11g – Flashback Data Archive. 2 Data History and Retention Data retention and change control requirements are growing Regulatory oversight.
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 7 PL/SQL Packages.
9 Copyright © 2004, Oracle. All rights reserved. Flashback Database.
1 Copyright © 2004, Oracle. All rights reserved. Introduction to PL/SQL.
PL/SQLPL/SQL Oracle11g : PL/SQL Programming Chapter 6 Functions.
Overview · What is PL/SQL · Advantages of PL/SQL · Basic Structure of a PL/SQL Block · Procedure · Function · Anonymous Block · Types of Block · Declaring.
6 Extraction, Transformation, and Loading (ETL) Transformation.
9 Copyright © Oracle Corporation, All rights reserved. Creating and Managing Tables.
1 Copyright © 2004, Oracle. All rights reserved. Introduction to PL/SQL.
12 Copyright © 2004, Oracle. All rights reserved. Understanding and Influencing the PL/SQL Compiler.
7 Copyright © 2005, Oracle. All rights reserved. Managing Undo Data.
11 Copyright © 2004, Oracle. All rights reserved. Dealing with Database Corruption.
What is a Package? A package is an Oracle object, which holds other objects within it. Objects commonly held within a package are procedures, functions,
Objectives Database triggers and syntax
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 9 Database Triggers.
14 Copyright © 2005, Oracle. All rights reserved. Backup and Recovery Concepts.
Dynamic SQL. 2 home back first prev next last What Will I Learn? Recall the stages through which all SQL statements pass Describe the reasons for using.
13 Copyright © Oracle Corporation, All rights reserved. Maintaining Data Integrity.
PL/SQLPL/SQL Oracle11g: PL/SQL Programming Chapter 9 Database Triggers.
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 9 Database Triggers.
PL/SQLPL/SQL Oracle10g Developer: PL/SQL Programming Chapter 8 Program Unit Dependencies.
Learningcomputer.com SQL Server 2008 –Views, Functions and Stored Procedures.
18 Copyright © 2004, Oracle. All rights reserved. Backup and Recovery Concepts.
20 Copyright © 2008, Oracle. All rights reserved. Cache Management.
PRACTICE OVERVIEW PL/SQL Part Your stored procedure, GET_BUDGET, has a logic problem and must be modified. The script that contains the procedure.
3 Copyright © 2007, Oracle. All rights reserved. Using the RMAN Recovery Catalog.
18 Copyright © 2004, Oracle. All rights reserved. Recovery Concepts.
Text TCS INTERNAL Oracle PL/SQL – Introduction. TCS INTERNAL PL SQL Introduction PLSQL means Procedural Language extension of SQL. PLSQL is a database.
14 Copyright © 2005, Oracle. All rights reserved. Backup and Recovery Concepts.
Oracle9i Developer: PL/SQL Programming Chapter 11 Performance Tuning.
Oracle9i Developer: PL/SQL Programming Chapter 5 Functions.
11 Copyright © 2007, Oracle. All rights reserved. Using Flashback Technology.
21 Copyright © 2008, Oracle. All rights reserved. Enabling Usage Tracking.
1 11g NEW FEATURES ByVIJAY. 2 AGENDA  RESULT CACHE  INVISIBLE INDEXES  READ ONLY TABLES  DDL WAIT OPTION  ADDING COLUMN TO A TABLE WITH DEFAULT VALUE.
SQL Triggers, Functions & Stored Procedures Programming Operations.
16 Copyright © 2007, Oracle. All rights reserved. Miscellaneous New Features.
 CONACT UC:  Magnific training   
5 Copyright © 2004, Oracle. All rights reserved. PL/SQL Server Pages.
20 Copyright © 2006, Oracle. All rights reserved. Best Practices and Operational Considerations.
8 Copyright © 2007, Oracle. All rights reserved. Implementing SecureFile LOBs.
3 Copyright © 2006, Oracle. All rights reserved. Designing and Developing for Performance.
14 Copyright © 2007, Oracle. All rights reserved. Backup and Recovery Concepts.
13 Copyright © 2004, Oracle. All rights reserved. Migrating SQL Statements.
Preface IIntroduction Course Objectives I-2 Oracle Complete Solution I-3 Course Agenda I-4 Tables Used in This Course I-5 The Order Entry Schema I-6 The.
6 Copyright © 2009, Oracle. All rights reserved. Using Dynamic SQL.
2 Copyright © 2009, Oracle. All rights reserved. Managing Schema Objects.
C Copyright © 2009, Oracle. All rights reserved. Using SQL Developer.
2 Copyright © 2008, Oracle. All rights reserved. Building the Physical Layer of a Repository.
11 Copyright © 2009, Oracle. All rights reserved. Enhancing ETL Performance.
9 Copyright © 2005, Oracle. All rights reserved. Managing Undo Data.
10 Copyright © 2007, Oracle. All rights reserved. Managing Undo Data.
Trigger used in PosgreSQL
Managing Privileges.
SQL Stored Triggers Presented by: Dr. Samir Tartir
Oracle 1Z0-148 Questions Answers VCE
Oracle9i Developer: PL/SQL Programming Chapter 8 Database Triggers.
Managing Privileges.
Chapter 7 Using SQL in Applications
Prof. Arfaoui. COM390 Chapter 9
Presentation transcript:

5 Copyright © 2007, Oracle. All rights reserved. Implementing the Performance Improvements

Copyright © 2007, Oracle. All rights reserved Objectives After completing this lesson, you should be able to: List the compiler changes and explain how the changes impact native compilation Use the new SIMPLE_INTEGER data type Describe the process of inlining Use caching for optimization Use flashback to store and track all transactional changes to a record

Copyright © 2007, Oracle. All rights reserved Lesson Agenda Compiler changes and how the changes impact native compilation The SIMPLE_INTEGER data type Inlining Caching –SQL result cache –PL/SQL function result cache Flashback enhancements –To store and track all transactional changes to a record over its lifetime

Copyright © 2007, Oracle. All rights reserved Real Native Compilation The compiler translates PL/SQL source directly to the dynamic-link library (DLL) for the current hardware. The compiler does the linking and loading so that the file system directories are no longer needed. The PL/SQL native compilation works out of the box, without requiring a C compiler on a production box. The PLSQL_CODE_TYPE parameter is the on/off switch. And, real native compilation is faster than the C native compilation.

Copyright © 2007, Oracle. All rights reserved Lesson Agenda Compiler changes and how the changes impact native compilation The SIMPLE_INTEGER data type Inlining Caching –SQL result cache –PL/SQL function result cache Flashback enhancements –To store and track all transactional changes to a record over its lifetime

Copyright © 2007, Oracle. All rights reserved SIMPLE_INTEGER Data Type Definition: –Is a predefined subtype –Has the range – –Does not include a null value –Is allowed anywhere in PL/SQL where the PLS_INTEGER data type is allowed Benefits: –Eliminates the overhead of overflow checking –Is estimated to be 2–10 times faster when compared with the PLS_INTEGER type with native PL/SQL compilation

Copyright © 2007, Oracle. All rights reserved SIMPLE_INTEGER Data Type: Example CREATE OR REPLACE PROCEDURE p IS t0 NUMBER :=0; t1 NUMBER :=0; $IF $$Simple $THEN SUBTYPE My_Integer_t IS SIMPLE_INTEGER; My_Integer_t_Name CONSTANT VARCHAR2(30) := 'SIMPLE_INTEGER'; $ELSE SUBTYPE My_Integer_t IS PLS_INTEGER; My_Integer_t_Name CONSTANT VARCHAR2(30) := 'PLS_INTEGER'; $END v00 My_Integer_t := 0; v01 My_Integer_t := 0; v02 My_Integer_t := 0; v03 My_Integer_t := 0; v04 My_Integer_t := 0; v05 My_Integer_t := 0; two CONSTANT My_Integer_t := 2; lmt CONSTANT My_Integer_t := ; -- continued on next page

Copyright © 2007, Oracle. All rights reserved SIMPLE_INTEGER Data Type: Example -- continued from previous page BEGIN t0 := DBMS_UTILITY.GET_CPU_TIME(); WHILE v01 < lmt LOOP v00 := v00 + Two; v01 := v01 + Two; v02 := v02 + Two; v03 := v03 + Two; v04 := v04 + Two; v05 := v05 + Two; END LOOP; IF v01 <> lmt OR v01 IS NULL THEN RAISE Program_Error; END IF; t1 := DBMS_UTILITY.GET_CPU_TIME(); DBMS_OUTPUT.PUT_LINE( RPAD(LOWER($$PLSQL_Code_Type), 15)|| RPAD(LOWER(My_Integer_t_Name), 15)|| TO_CHAR((t1-t0), '9999')||' centiseconds'); END p; /

Copyright © 2007, Oracle. All rights reserved SIMPLE_INTEGER Data Type: Example ALTER PROCEDURE p COMPILE PLSQL_Code_Type = NATIVE PLSQL_CCFlags = 'simple:true' REUSE SETTINGS; Procedure altered. EXECUTE p() native simple_integer 51 centiseconds PL/SQL procedure successfully completed. ALTER PROCEDURE p COMPILE PLSQL_Code_Type = native PLSQL_CCFlags = 'simple:false' REUSE SETTINGS; Procedure altered. EXECUTE p() native pls_integer 884 centiseconds PL/SQL procedure successfully completed

Copyright © 2007, Oracle. All rights reserved Lesson Agenda Compiler changes and how the changes impact native compilation The SIMPLE_INTEGER data type Inlining Caching –SQL result cache –PL/SQL function result cache Flashback enhancements –To store and track all transactional changes to a record over its lifetime

Copyright © 2007, Oracle. All rights reserved Intra Unit Inlining Definition: –Inlining is defined as the replacement of a call to subroutine with a copy of the body of the subroutine that is called. –The copied procedure generally runs faster than the original. –The PL/SQL compiler can automatically find the calls that should be inlined. Benefits: –Inlining can provide large performance gains when applied judiciously by a factor of 2–10 times.

Copyright © 2007, Oracle. All rights reserved Use of Inlining Influence implementing inlining via two methods: –Oracle parameter PLSQL_OPTIMIZE_LEVEL – PRAGMA INLINE Recommend that you: –Inline small programs –Inline programs that are frequently executed Use performance tools to identify hot spots suitable for inline applications: – plstimer

Copyright © 2007, Oracle. All rights reserved Inlining Concepts Noninlined program: CREATE OR REPLACE PROCEDURE small_pgm IS a NUMBER; b NUMBER; PROCEDURE touch(x IN OUT NUMBER, y NUMBER) IS BEGIN IF y > 0 THEN x := x*x; END IF; END; BEGIN a := b; FOR I IN LOOP touch(a, -17); a := a*b; END LOOP; END small_pgm;

Copyright © 2007, Oracle. All rights reserved Inlining Concepts Examine the loop after inlining:... BEGIN a := b; FOR i IN LOOP IF –17 > 0 THEN a := a*a; END IF; a := a*b; END LOOP; END small_pgm;...

Copyright © 2007, Oracle. All rights reserved Inlining Concepts The loop is transformed in several steps: a := b; FOR i IN LOOP... IF false THEN a := a*a; END IF; a := a*b; END LOOP; a := b; FOR i IN LOOP... a := a*b; END LOOP; a := b; a := a*b; FOR i IN LOOP... END LOOP; a := b*b; FOR i IN LOOP... END LOOP;

Copyright © 2007, Oracle. All rights reserved Inlining: Example Set the PLSQL_OPTIMIZE_LEVEL session-level parameter to a value of 2 or 3: –Setting it to 2 means no automatic inlining is attempted. –Setting it to 3 means automatic inlining is attempted and no pragmas are necessary. Within a PL/SQL subroutine, use PRAGMA INLINE –NO means no inlining occurs regardless of the level and regardless of the YES pragmas. –YES means inline at level 2 of a particular call and increase the priority of inlining at level 3 for the call. ALTER PROCEDURE small_pgm COMPILE PLSQL_OPTIMIZE_LEVEL = 3 REUSE SETTINGS;

Copyright © 2007, Oracle. All rights reserved Inlining: Example After setting the PLSQL_OPTIMIZE_LEVEL parameter, use a pragma: CREATE OR REPLACE PROCEDURE small_pgm IS a PLS_INTEGER; FUNCTION add_it(a PLS_INTEGER, b PLS_INTEGER) RETURN PLS_INTEGER IS BEGIN RETURN a + b; END; BEGIN pragma INLINE (small_pgm, 'YES'); a := add_it(3, 4) + 6; END small_pgm;

Copyright © 2007, Oracle. All rights reserved Inlining: Guidelines Pragmas apply only to calls in the next statement following the pragma. Programs that make use of smaller helper subroutines are good candidates for inlining. Only local subroutines can be inlined. You cannot inline an external subroutine. Cursor functions should not be inlined. Inlining can increase the size of a unit. Be careful about suggesting to inline functions that are deterministic.

Copyright © 2007, Oracle. All rights reserved Lesson Agenda Compiler changes and how the changes impact native compilation The SIMPLE_INTEGER data type Inlining Caching –SQL result cache –PL/SQL function result cache Flashback enhancements –To store and track all transactional changes to a record over its lifetime

Copyright © 2007, Oracle. All rights reserved SQL Query Result Cache Definition: –Cache the results of the current query or query fragment in memory and then use the cached results in future executions of the query or query fragments. –Cached results reside in the result cache memory portion of the SGA. Benefits: –Improved performance

Copyright © 2007, Oracle. All rights reserved SQL Query Result Cache Scenario: –You need to find the greatest average value of credit limit grouped by state over the whole population. –The query results in a huge number of rows analyzed to yield a few or one row. –In your query, the data changes fairly slowly (say every hour) but the query is repeated fairly often (say every second). Solution: –Use the new optimizer hint /*+ result_cache */ in your query: SELECT /*+ result_cache */ AVG(cust_credit_limit), cust_state_province FROM sh.customers GROUP BY cust_state_province;

Copyright © 2007, Oracle. All rights reserved PL/SQL Function Result Cache Definition: –Enables data that is stored in cache to be shared across sessions –Stores the function result cache in a shared global area (SGA), making it available to any session that runs your application Benefits: –Improved performance –Improved scalability

Copyright © 2007, Oracle. All rights reserved PL/SQL Function Result Cache Scenario: –You need a PL/SQL function that derives a complex metric. –The data that your function calculates changes slowly, but the function is frequently called. Solution: –Use the new result_cache clause in your function definition.

Copyright © 2007, Oracle. All rights reserved Enabling Result Caching Include the RESULT_CACHE option in the function definition. Optionally, include the RELIES_ON clause. CREATE OR REPLACE FUNCTION productName (prod_id NUMBER, lang_id VARCHAR2) RETURN NVARCHAR2 RESULT_CACHE RELIES_ON (product_descriptions) IS result VARCHAR2(50); BEGIN SELECT translated_name INTO result FROM product_descriptions WHERE product_id = prod_id AND language_id = lang_id; RETURN result; END;

Copyright © 2007, Oracle. All rights reserved Lesson Agenda Compiler changes and how the changes impact native compilation The SIMPLE_INTEGER data type Inlining Caching –SQL result cache –PL/SQL function result cache Flashback enhancements –To store and track all transactional changes to a record over its lifetime

Copyright © 2007, Oracle. All rights reserved Flashback Data Archives Provide the ability to store and track all transactional changes to a record over its lifetime Save development resources because you no longer need to build this intelligence into your application Are useful for compliance with record stage policies and audit reports

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive Process 1.Create the Flashback Data Archive. 2.Specify the default Flashback Data Archive. 3.Enable the Flashback Data Archive. 4.View Flashback Data Archive data.

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive Scenario Using Flashback Data Archive to access historical data: CONNECT AS sysdba -- create the Flashback Data Archive CREATE FLASHBACK ARCHIVE DEFAULT fla1 TABLESPACE example QUOTA 10G RETENTION 5 YEAR; -- Enable Flashback Data Archive ALTER TABLE oe1.inventories FLASHBACK ARCHIVE; ALTER TABLE oe1.warehouses FLASHBACK ARCHIVE; -- Specify the default Flashback Data Archive ALTER FLASHBACK ARCHIVE fla1 SET DEFAULT; 1 2 3

Copyright © 2007, Oracle. All rights reserved

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive Scenario Using Flashback Data Archive to access historical data: Examine the data: Change the data: Examine the flashback data: SELECT product_id, warehouse_id, quantity_on_hand FROM oe1.inventories AS OF TIMESTAMP TO_TIMESTAMP (' :00:00', 'YYYY-MM-DD HH24:MI:SS') WHERE product_id = 3108; SELECT product_id, warehouse_id, quantity_on_hand FROM oe1.inventories WHERE product_id = 3108; UPDATE oe1.inventories SET quantity_on_hand = 300 WHERE product_id = 3108; 1 2 3

Copyright © 2007, Oracle. All rights reserved

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive Dictionary Views Viewing the results: View NameDescription *_FLASHBACK_ARCHIVE Displays information about Flashback Data Archives *_FLASHBACK_ARCHIVE_TS Displays tablespaces of Flashback Data Archives *_FLASHBACK_ARCHIVE_TABLES Displays information about tables that are enabled for flashback archiving

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive Dictionary Views Viewing information about tables that are enabled for flashback archiving: DESCRIBE dba_flashback_archive_tables Name Null? Type TABLE_NAME NOT NULL VARCHAR2(30) OWNER_NAME NOT NULL VARCHAR2(30) FLASHBACK_ARCHIVE_NAME NOT NULL VARCHAR2(255) ARCHIVE_TABLE_NAME VARCHAR2(53) SELECT * FROM dba_flashback_archive_tables; TABLE_NAME OWNER_NAME FLASHBACK_ARCHIVE_NAME ARCHIVE_TABLE_NAME INVENTORIES OE FLA1 SYS_FBA_HIST_70355 WAREHOUSES OE FLA1 SYS_FBA_HIST_70336

Copyright © 2007, Oracle. All rights reserved Flashback Data Archive DDL Restrictions Using any of the following DDL statements on a table enabled for Flashback Data Archive causes the error ORA-55610: Invalid DDL statement on history-tracked table ALTER TABLE statement that does any of the following: –Drops, renames, or modifies a column –Performs partition or subpartition operations –Converts a LONG column to a LOB column –Includes an UPGRADE TABLE clause, with or without an INCLUDING DATA clause DROP TABLE statement RENAME TABLE statement TRUNCATE TABLE statement

Copyright © 2007, Oracle. All rights reserved Summary In this lesson, you should have learned how to: List the compiler changes and explain how the changes impact native compilation Use the new SIMPLE_INTEGER data type Describe the process of inlining Use caching for optimization Use flashback to store and track all transactional changes to a record

Copyright © 2007, Oracle. All rights reserved Practice 5 Overview: Implementing Performance Improvements This practice covers the following topics: Testing the performance of the SIMPLE_INTEGER data type Writing code to use SQL caching Writing code to use PL/SQL caching Examining inlined code and practicing how to influence inlining

Copyright © 2007, Oracle. All rights reserved Notes Page Only

Copyright © 2007, Oracle. All rights reserved Notes Page Only

Copyright © 2007, Oracle. All rights reserved Notes Page Only

Copyright © 2007, Oracle. All rights reserved Notes Page Only

Copyright © 2007, Oracle. All rights reserved Notes Page Only

Copyright © 2007, Oracle. All rights reserved Notes Page Only