- Case 1: With and Without Index
- Case 2: Compare Single Column Index Access path
- Case 3: Concatenated Index
- Case 4: Bitmap Index Access
- Case 5: Index Only Access
- Case 6: Bitmap Index only Access
- Case 7: B*Tree index only Access
- Case 8: Function based index
- Oracle Database 11g Enterprise Edition with access to the Tuning and Diagnostic management packs and with the sample schema installed.
- Oracle SQL Developer 3.2.
- Download Oracle SQL Developer 3.2 here.
Introduction
In this tutorial you will use the Optimizer Access Paths for the following cases (scenarios):
Hardware and Software Requirements
The following is a list of hardware and software requirements:
Prerequisites
Note: For best results, use Firefox or Chrome browsers to view this tutorial.
The first step to using the optimizer access path is to create a database connection.
Perform the following steps to create a database connection:
Click the SQL Developer 3.2 icon on your Desktop to start SQL Developer.
data:image/s3,"s3://crabby-images/c0bac/c0bac8cd451ff8d327108ba2806ec494e204f8b1" alt="images/sql%20dev%203.2%20logo.gif"
Your Oracle SQL Developer 3.2 opens up.
data:image/s3,"s3://crabby-images/6480f/6480f6d4010cea6e68174dbd5e3acba4dd708303" alt="images/sqldev-startup.gif"
In the Connections navigator, right-click Connections and select New Connection.
The New / Select Database Connection dialog opens. Enter the connection details as follows and click Test.
Connection Name: hr_conn
Username: hr
Password: <your_password >(Select Save Password)
Hostname: localhost
SID: <your_own_SID>
data:image/s3,"s3://crabby-images/2baee/2baeef4cb4cef0fc49f89c37e991c5beab0b19b8" alt="images/test-conn.gif"
Check for the status of the connection on the left-bottom side (above the Help button). It should read Success. Click Save and then click Connect.
data:image/s3,"s3://crabby-images/31488/31488ad9f92c45e10683da4dd2edb250a8784852" alt="images/success-conn.gif"
To view the difference in performance when using an index, versus when not, perform the following steps:
Right-click hr_conn and select Open SQL Worksheet.
data:image/s3,"s3://crabby-images/7f713/7f71339bdc410a043411e7ef69692827d398f0f1" alt="images/open-sheet.gif"
Drop all the indexes on the employees table except the primary key and unique key indexes ( *_PK, *_UK).
drop index EMP_JOB_IX;
drop index EMP_NAME_IX;
drop index EMP_MANAGER_IX;
drop index EMP_DEPARTMENT_IX;
Autotrace the query.
data:image/s3,"s3://crabby-images/2b4f8/2b4f89dd949dfab1395b1986b67fbd95da6ce2b9" alt="images/autotrace-1.gif"
Observe the output. You will notice there are no indexes on the employees table.
The only possibility for the optimizer is to use a full scan to retrieve the rows. You can see that the full table scan takes a long time.
data:image/s3,"s3://crabby-images/99b8b/99b8ba84d9fee9a4138a899e2ebb630a9d31013e" alt="images/autotrace-res.gif"
To enhance the performance of the query in Step 1, create an index.
create index emp_idx_dept_no on hr.employees(department_id) nologging compute statistics;
data:image/s3,"s3://crabby-images/d7bec/d7bec95376b1d4e56f8bb96a96ac7469fd2625de" alt="images/emp-idx.gif"
Autotrace the query in Step 1 again and observe the output.
data:image/s3,"s3://crabby-images/f5fdd/f5fdd429c70d961611f171a468e17431cc2466aa" alt="images/autotrace-emp-idx.gif"
You can see a significant improvement in performance. Note the difference in time, cost and physical reads.
To compare single column index access, perform the following steps:
Connect to the hr schema. Drop all the indexes on the employees table except the primary key and unique key indexes ( *_PK, *_UK).
drop index EMP_IDX_DEPT_NO;
Aurotrace the query:
SELECT /*+ FULL(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000;
data:image/s3,"s3://crabby-images/79e01/79e01e9fb09113bea97955880f3989aa951679d7" alt="images/c2-autotrace-res.gif"
Create two B*-tree indexes on department_id and salary column of the employees table.
CREATE INDEX emp_dept_id_idx ON employees(department_id) NOLOGGING COMPUTE STATISTICS;
CREATE INDEX emp_sal_idx ON employees(salary) NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/738c5/738c5b55ae4c2a9a5a143d4dcf199c0a88bde482" alt="images/b-tree.gif"
To start monitoring the use of the employees index, run the following statements:
ALTER INDEX emp_dept_id_idx MONITORING USAGE;
ALTER INDEX emp_sal_idx MONITORING USAGE;
data:image/s3,"s3://crabby-images/2290b/2290b048cce2b9f932d63c35ba03bc8c706760e3" alt="images/c2-alterindex.gif"
Autotrace the query in Step 2:
SELECT /*+ FULL(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000;
data:image/s3,"s3://crabby-images/a2440/a24409f0a7117485ec84d8ca8ab6a029fdc9822d" alt="images/c2-btree-trace.gif"
You will notice there are no indexes on the employees table.
The only possibility for the optimizer is to use a full scan to retrieve the rows. You can see that the full table scan takes place again.
Now Autotrace the query:
SELECT /*+ INDEX_COMBINE(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000;
You will notice that this time the optimizer uses multiple indexes and combines them to access the table. The cost is lower than the full table scan.
data:image/s3,"s3://crabby-images/e1a14/e1a14b3493804dae8e3cbc74e7b94a893525f91f" alt="images/c2-autotrace2.gif"
To view the performance of a query using concatenated index, perform the following statements:
Connect to the hr schema. Drop all the indexes on the employees table except the primary key index.
drop index EMP_DEPT_ID_IDX;
drop index EMP_SAL_IDX;
Create a concatenated index on department_id, salary, hire_date column of the employees table.
CREATE INDEX emp_dept_id_sal_hiredt_idx
ON employees(department_id,salary,hire_date)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/164c6/164c6333a25e8c54b0a2dfba9c17a53cba2dfdcd" alt="images/c3-createindex.gif"
Autotrace the query:
SELECT /*+INDEX(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000
AND hire_date between '13-JAN-07' AND '13-JAN-08';
You will notice the optimizer uses concatenated index and the resulting cost is quite good.
data:image/s3,"s3://crabby-images/65e3a/65e3a22fc413b29d1b4f898e7500f0e25dced3a3" alt="images/concat.gif"
Autotrace the query:
SELECT /*+INDEX(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000;
The query is quite similar to the previous step, but the predicate on HIRE_DATE is removed.
The optimizer can still use the concatenated index.
data:image/s3,"s3://crabby-images/bdd0c/bdd0c08887cc039583fbe2b172af775565430279" alt="images/concat1.gif"
Autotrace the query:
SELECT /*+INDEX(e)*/e.*
FROM employees e
WHERE salary > 1000
AND hire_date between '13-JAN-07' AND '13-JAN-08';
The leading part of the concatenated index is no longer a part of the query. However, the optimizer still uses the index by using a full index scan.
data:image/s3,"s3://crabby-images/64b8c/64b8c10b9f056fc3210d603c0acf1152900e5089" alt="images/concat2.gif"
To view the performance of a query using bitmap index, perform the following statements:
Connect to the hr schema. Drop all the indexes on the employees table except the primary key index.
drop index EMP_DEPT_ID_SAL_HIREDT_IDX;
Create the following bitmap indexes:
CREATE BITMAP INDEX emp_dept_id_bidx
ON employees(department_id)
NOLOGGING COMPUTE STATISTICS;
CREATE BITMAP INDEX emp_sal_bidx
ON EMPLOYEES(salary)
NOLOGGING COMPUTE STATISTICS;
CREATE BITMAP INDEX emp_hire_date_bidx
ON employees(hire_date)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/7d124/7d12425b531c13fcb43bfeb577bdf0cc8940916d" alt="images/c4-step2.gif"
Autotrace the query:
SELECT /*+INDEX_COMBINE(e)*/e.*
FROM employees e
WHERE department_id = 10
AND salary > 1000
AND hire_date between '13-JAN-07' AND '13-JAN-08';
You will notice that the query uses all the bitmap indexes to solve this query.
However the cost is good. The cost is a little lower than the cost of the full table scan.
data:image/s3,"s3://crabby-images/db0b7/db0b721fd6b7d0035f2e63238f335097edb25297" alt="images/bitmap.gif"
To view the performance of a query using only index access, perform the following statements:
Connect to the hr schema. Drop all the indexes on the employees table except the primary key index.
drop index EMP_DEPT_ID_BIDX;
drop index EMP_SAL_BIDX;
drop index EMP_HIRE_DATE_BIDX;
Create an index on the first_name and salary columns of the employees table.
CREATE INDEX emp_last_first_name_idx
ON employees(last_name,first_name)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/71432/7143240a055d64ed728a67f87ae0225dc4f1930d" alt="images/first.gif"
Autotrace the query:
SELECT e.last_name, e.first_name
FROM employees e;
You will observe that the optimizer can use the index to retrieve the entire select list without accessing the table itself. The cost is good.
data:image/s3,"s3://crabby-images/719ac/719ac7fa71a1200804b8e6985b3b4a9076723a0c" alt="images/first1.gif"
To view the performance of a query using only bitmap index access, perform the following statements:
In the Connections navigator, right-click Connections and select New Connection.
The New / Select Database Connection dialog opens. Enter the connection details as follows and click Test.
Connection Name: sh
Username: sh
Password: <your_password >(Select Save Password)
Hostname: localhost
SID: <your_own_SID>
data:image/s3,"s3://crabby-images/32ddc/32ddc903d90380f40f1737843d5d28acb1cb2350" alt="images/sh_conn.gif"
Check for the status of the connection on the left-bottom side (above the Help button). It should read Success. Click Save and then click Connect.
data:image/s3,"s3://crabby-images/910f1/910f1cf34695a386ef1bffe1f467300fa68e1c79" alt="images/sh_conn1.gif"
Drop all the indexes on the customers table except the primary key index and unique key index(*_PK, *_UK).
DROP INDEX customers_gender_bix ;
DROP INDEX cust_cust_credit_limit_idx;
DROP INDEX cust_cust_postal_code_bidx;
DROP INDEX emp_first_name_sal_idx;
Create a bitmap index on the cust_credit_limit column of the customers table.
CREATE BITMAP INDEX cust_cust_credit_limit_bidx ON CUSTOMERS(cust_credit_limit)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/b11ba/b11ba0dcc0ef7a309d88678c11cad404a8415950" alt="images/NEW_BITMAP.gif"
Autotrace the query:
SELECT count(*) credit_limit
FROM CUSTOMERS
WHERE cust_credit_limit=2000;
You will notice that though salary is not a selective column, the COUNT operation on its bitmap index is very efficient.
data:image/s3,"s3://crabby-images/f6fd2/f6fd25db2b4889024094a78b0715f0d29b600510" alt="images/NEW_BITMAP1.gif"
To view the performance of a query using only bitmap index access, perform the following statements:
Connect to the sh schema. Drop all the indexes on the customers table except the primary key index.
DROP INDEX cust_cust_credit_limit_bidx;
Create a B* Tree index on the cust_credit_limit column of the customers table.
CREATE INDEX cust_cust_credit_limit_idx ON CUSTOMERS(cust_credit_limit)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/c137c/c137ccefac19c850e2d9a807e05ec1c2567301e8" alt="images/NEW_INDEX.gif"
Autotrace the query:
SELECT count(*) credit_limit
FROM CUSTOMERS
WHERE cust_credit_limit=2000;
You will notice that the optimizer uses the B*Tree index; however this is less efficient compared to the corresponding bitmap index from the previous case.
data:image/s3,"s3://crabby-images/65b6c/65b6c168f7dd5d4aaff0ef3395f7c4e1ad06323f" alt="images/NEW_INDEX1.gif"
To view the performance of a query using only function based index, perform the following statements:
Connect to the hr schema. Drop all the indexes on the employees table except the primary key index.
drop index EMP_SAL_BIDX;
Create a B* Tree index on the first_name column of the employees table.
CREATE INDEX emp_fname_idx ON employees(first_name)
NOLOGGING COMPUTE STATISTICS;
data:image/s3,"s3://crabby-images/93706/9370694c81fbce7e97aedc9dd3663485a463f248" alt="images/c8-step2.gif"
Autotrace the query:
SELECT employee_id, department_id
FROM EMPLOYEES
WHERE LOWER(first_name) like 's%';
You will notice that though there is an index, it cannot be used because its column is modified by a function.
data:image/s3,"s3://crabby-images/bdf19/bdf19e4a0333d20f4432e5cabe25859e95b57a13" alt="images/c8-step3.gif"
To enhance the performance of this query, you can create a function based index:
CREATE INDEX emp_lower_fname_idx ON employees(LOWER(first_name));
data:image/s3,"s3://crabby-images/f5824/f5824293606f7b217190b4a2dc0f3d19b3321c64" alt="images/c8-step4.gif"
Autotrace the query in Step 3 again. You will notice the performance of the query is much better now.
data:image/s3,"s3://crabby-images/2a82b/2a82bfbe1f0623414c8cd3ff23a71cdb04a0289e" alt="images/c8-step5-new.gif"
No comments:
Post a Comment