Minimize
Blogger List

Johannes Ahrends
Toad and Oracle

Ben Boise
Toad SC Discussions

Kevin Dalton
Benchmark Factory

Steven Feuerstein
PL/SQL Obsession

Devin Gallagher
Toad SC discussions

Stuart Hodgins
JProbe Discussions

  Henrik "Mauritz" Johnson
Toad Tips & Tricks on the "other" Toads
  Mark Kurtz
Toad SC discussions
  Michael Lumbard
Toad SC discussions
Daniel Norwood
Toad for Data Analysts,
Toad Extension for Visual Studio
Debbie Peabody
Toad for Data Analysts
Gary Piper
Toad Reports Manager
John Pocknell
Toad for Oracle, JProbe
Kuljit Sangha
Toad SC discussions
Bert Scalzo Indicates Oracle ACE status
Toad for Oracle, Data Modeling, Benchmarking
Jeff Smith
Toad product family
Richard To
SQL Optimization
Jim Wankowski
DB2 - LUW and z/OS
John Weathington
  Toad Data Modeler Opens in a new window
Data Modeling
 
  Real Automated Code Testing for Oracle
Quest Code Tester blog
 
Minimize
Blog Tags
toad for oracle (122)
oracle (62)
plsql (46)
sql optimization (37)
toad for data analysts (28)
code tester (19)
toad for ibm db2 (13)
automation (11)
batch optimizer (10)
virtualization (10)
schema browser (9)
toad for sql server (9)
data grid (8)
sql (8)
sql editor (8)
toad data modeler (8)
benchmark factory (7)
excel (7)
query builder (7)
report manager (7)
toad extension (7)
visual studio (7)
11g (6)
configuration (6)
freeware (6)
health check (6)
vmware (6)
connect (5)
dba module (5)
er diagrammer (5)
F4 (5)
linux (5)
refactoring (5)
spotlight (5)
unicode (5)
compare (4)
debugger (4)
export (4)
formatter (4)
make code (4)
rman (4)
strip code (4)
benchmark (3)
bfscript (3)
bulk collect (3)
code templates (3)
code xpert (3)
database browser (3)
db2 (3)
notebook (3)
oem (3)
RAC (3)
session browser (3)
speed (3)
sql optimizer (3)
toad for mysql (3)
tpc-c (3)
9.7 (2)
alert log (2)
app designer (2)
awr (2)
code insight (2)
code snippets (2)
collection (2)
compare and sync (2)
compliance (2)
data generator (2)
data warehouse (2)
database explorer (2)
database monitor (2)
explain (2)
forall (2)
ftp (2)
group execute (2)
handbook (2)
installation (2)
job scheduler (2)
multi-task (2)
nested table (2)
os command (2)
profiler (2)
recovery (2)
release history (2)
save as (2)
schema compare (2)
sql recall (2)
stats pack (2)
subversion (2)
team coding (2)
trace file browser (2)
while loop (2)
10g (1)
64 bit (1)
7zip (1)
action (1)
addm (1)
alter (1)
ansi join (1)
array (1)
ccleaner (1)
code coverage (1)
code road map (1)
CRON (1)
cursor for loop (1)
data browser (1)
data subset (1)
database probe (1)
dbms_flashback (1)
dbms_profiler (1)
ddl (1)
feuerstein (1)
filezilla (1)
flash drive (1)
flow control (1)
for loop (1)
group policy manager (1)
hints (1)
import (1)
index (1)
inheritance (1)
invoker rights (1)
ipad (1)
java (1)
latency (1)
log switch (1)
logical model (1)
ltrim (1)
master-detail browser (1)
monitor (1)
multi-select (1)
naming standards (1)
network (1)
object explorer (1)
OEBS (1)
package (1)
parser (1)
partitioning (1)
performance (1)
pragma (1)
project manager (1)
RAT (1)
revo (1)
REXEC (1)
schema report (1)
script manager (1)
search (1)
set operator (1)
sga (1)
slow (1)
sonarsource (1)
source control (1)
space projection (1)
sql monitor (1)
sql navigator (1)
sql script (1)
sql tracker (1)
sql*plus (1)
standards (1)
statistics (1)
stored procedure (1)
string parser (1)
sub-model (1)
sub-type (1)
synch (1)
synchback (1)
TELNET (1)
toad (1)
trace (1)
unit test (1)
unix (1)
usb (1)
utility (1)
v10 (1)
v9.5 (1)
version control (1)
waits (1)
workload replay (1)
workspace (1)
xml (1)
 
WELCOME, GUEST
 
 

Blogs
Toad and Database Commentaries

Toad World blogs are a mix of insightful how-tos from Quest experts as well as their commentary on experiences with new database technologies.  Have some views of your own to share?  Post your comments!  Note:  Comments are restricted to registered Toad World users.

Do you have a topic that you'd like discussed?  We'd love to hear from you.  Send us your idea for a blog topic.


Jan 2

Written by: Richard To
Friday, January 02, 2009 7:11 AM  RssIcon

Written by Rene Woody

This blog is a continuation of a series about the SQL optimization process in the Batch Optimizer and the Tuning Lab modules of Quest SQL Optimizer for Oracle. It explains how the Oracle optimization hints are applied to the SQL statements to generate more execution plans.
 
One technique that you can use to improve the performance of a SQL statement is to add an Oracle optimization hint. Oracle provides “hints” that can be added to the syntax of a SQL statement to attempt to influence the database optimizer to use a particular execution plan to execute the SQL statement.
 
Quest SQL Optimizer for Oracle uses this technique in its SQL optimization process. After the syntax of a SQL statement is rewritten, Quest SQL Optimizer adds the Oracle optimization hints to the original SQL statement and the SQL alternatives that it has generated. It is seeing if it can find more unique execution plans using the Oracle hints.
 
This is a straight forward process when the SQL statement has only one SELECT statement. In this case, each hint is applied to that one SELECT statement. But when the SQL statement has multiple SELECTs within it, you can apply the hints to each SELECT in a plethora of combines.
 
Here is the approach that Quest SQL Optimizer uses to apply the hints for a SQL statement with multiple SELECTs such as this one with three SELECTs:
 
SELECT * 
 FROM EMPLOYEEx, 
       DEPARTMENTx DEPARTMENT1, 
       GRADEx 
 WHERE EMP_GRADE = GRD_ID 
   AND EMP_DEPT = DPT_ID 
   AND EXISTS (SELECT 'X' 
                 FROM DEPARTMENTx DEPARTMENT2 
                WHERE DPT_AVG_SALARY IN (SELECT MIN(DPT_AVG_SALARY) 
                                           FROM DEPARTMENTx DEPARTMENT3) 
                  AND DPT_ID = EMPLOYEEx.EMP_DEPT)
 
The hints are applied in a manner like this until most of the possible combinations with all the hints is tried or until the quota setting is reached.
 
The SQL Optimizer tries most of the  possible combinations of the first hint, in this case /*+ hint1 */. In this example, there are 7 different transformations using only the first hint.
 
SELECT /*+ hint1 */
   AND EXISTS (SELECT …
                  (SELECT …)
 
SELECT …
   AND EXISTS (SELECT /*+ hint1 */ 
                  (SELECT …)
 
SELECT …
   AND EXISTS (SELECT …
                  (SELECT /*+ hint1 */…)
 
SELECT /*+ hint1 */
   AND EXISTS (SELECT /*+ hint1 */
                  (SELECT …)
 
SELECT /*+ hint1 */
   AND EXISTS (SELECT … 
                  (SELECT /*+ hint1 */…)
 
SELECT …
   AND EXISTS (SELECT /*+ hint1 */
                  (SELECT /*+ hint1 */…)
 
SELECT /*+ hint1 */
   AND EXISTS (SELECT /*+ hint1 */
                  (SELECT /*+ hint1 */ …)
 
 
Then it moves on to the second hint. It applies the first hint to one SELECT and the second hint to another SELECT like this:
 
SELECT /*+ hint1 */
   AND EXISTS (SELECT /*+ hint2 */
                  (SELECT …)
 
So, it tries most of the possible combinations of applying all the selected hints. Since this can be quite a large number of combinations, you can limit the maximum number of SQL alternatives that are created by applying the Oracle optimization hints using the Hints Quota setting.
 
On the other hand, if you would like the optimization process to apply several of the Oracle optimization hints when there are multiple SELECT statements in one SQL statement you will need to use a large Hints Quota
 
 
If you would like to learn more about Quest SQL Optimizer for Oracle, please visit the Inside SQL Optimizer for Oracle community.

Search Blog Entries