Oracle Indexes   «Prev  Next»

Lesson 3 Types of indexes
ObjectiveUnderstand the types of indexes supported by Oracle.

Oracle Index Types

All indexes serve the same purpose which is to speed the execution of SQL statements. You can declare an index to be either unique, which means that all values in the index occur only once, or non-unique, which allows repeating values. The UNIQUE and PRIMARY KEY constraints use unique indexes to implement the constraint. Oracle supports two basic types of index structures which are the B*-tree index and the bitmapped index.
  • B*-tree Index
    The B*-tree index organizes data in an inverted tree structure. Each level in the structure is referred to as a node, and the bottom level in the B*-tree structure is called the leaf block. Starting at the top node, each block in the node contains a series of comparison values. Depending on where the value for an entry in the index falls in comparison to the values in the node, a user query travels to another node in the next level of the tree. This type of navigation is shown in the diagram below.

b-tree Index
The diagram represents a B-tree structure, commonly used in database indexing. Here's an analysis of the tree structure:
General Description
  1. Tree Levels
    • The tree has three levels:
    • Root Node (Level 1)
    • Intermediate Nodes (Level 2)
    • Leaf Nodes (Level 3)
  2. Node Structure
    • Each node contains a set of keys and links (pointers).
    • Keys are sorted within each node.
    • Pointers connect to child nodes or records at the next level.
  3. Data Layout
    • The root node at the top is labeled <Jones Jones>.
    • Intermediate nodes split the data further into sub-ranges:
    • <Jones Niles Turner> and <Brown Brown Edwards>.
    • Leaf nodes contain the individual data entries:
    • For example, Jones Miller, Niles Scott Smith, and so on.
  4. Leaf Node Content
    • Leaf nodes store individual entries or pointers to them, such as:
    • Brown-ROWID, Chasen-ROWID, Dirksen-ROWID, indicating direct references (e.g., database row identifiers).

Key Observations:
  • Hierarchy: Each level refines the search space further. At the root level, broad keys divide the dataset. At the intermediate level, narrower ranges refine the search further. At the leaf level, exact entries or references to the data are stored.
  • Balanced Tree: A B-tree is typically balanced, meaning all leaf nodes are at the same depth, ensuring efficient lookup, insertion, and deletion operations.
  • Sorting: Keys within nodes are sorted to allow for binary search, which optimizes lookup performance.

Use Case:
This tree structure likely represents a database index where:
  • The root and intermediate nodes act as navigational elements.
  • The leaf nodes provide direct references to the data (e.g., through ROWIDs).

  1. Top node: The topmost node provides an entry point. If the desired value is less than “Jones”, the retrieval proceeds to the left. If the desired value is greater than “Jones”, the retrieval proceeds to the right.
  2. Middle nodes: Each node contains comparison values that direct the retrieval to another level of nodes or to the leaf blocks.
  3. Leaf blocks: The leaf blocks contain the actual index values and the ROWIDs for the associated nodes. Each leaf block only contains a few values.
  4. Expanded leaf block: The actual data in the leaf block consists of the value for the index and the ROWID of the row of the data table that contains it.

Using a Different Index Type

There are several index types available, and each index has benefits for certain situations. The following list gives performance ideas associated with each index type.
  1. B-Tree Indexes: These are the standard index type, and they are excellent for primary key and highly-selective indexes. Used as concatenated indexes, B-tree indexes can be used to retrieve data sorted by the index columns.
  2. Bitmap Indexes: These are suitable for low cardinality data. Through compression techniques, they can generate a large number of rowids with minimal I/O.Combining bitmap indexes on non-selective columns allows efficient AND and OR operations with a great number of rowids with minimal I/O. Bitmap indexes are particularly efficient in queries with COUNT(), because the query can be satisfied within the index.
  3. Function-based Indexes: These indexes allow access through a B-tree on a value derived from a function on the base data. Function-based indexes have some limitations with regards to the use of nulls, and they require that you have the query optimizer enabled. Function-based indexes are particularly useful when querying on composite columns to produce a derived result or to overcome limitations in the way data is stored in the database. An example of this is querying for line items in an order exceeding a certain value derived from (sales price - discount) x quantity, where these were columns in the table. Another example is to apply the UPPER function to the data to allow case-insensitive searches.
  4. Partitioned Indexes: Partitioning a global index allows partition pruning to take place within an index access, which results in reduced I/Os. By definition of good range or list partitioning, fast index scans of the correct index partitions can result in very fast query times.
  5. Reverse Key Indexes: These are designed to eliminate index hot spots on insert applications. These indexes are excellent for insert performance, but they are limited in that they cannot be used for index range scans.

  • B*-tree index Structure
    The B*-tree index structure has several advantages:
    1. The branching structure dramatically reduces the amount of I/O to get to a particular block.
    2. Because all the index entries are located in the leaf blocks, and all leaf blocks are the same number of levels below the starting node, retrieval for all rows takes the same amount of overhead, regardless of where the entry falls in the table.
  • Bitmapped index
    A bitmapped index is organized by index values, and each bit in the bitmap points back to a particular ROWID. If the bit has a value of 1, the corresponding row contains that value, as shown in the MouseOver below.
    Bitmap Values Green
    | Values | Bitmap         |
    |--------|----------------|
    | Red    | 00110001010    |
    | Blue   | 10001000100    |
    | Green  | 01000110011    |
    

    The image also highlights the value "Green" with a reference arrow pointing to a single box that contains "Green" with a placeholder ("-") next to it, likely indicating a selection or reference in the context of the bitmap data.
    1. Each value contains a series of bits, each of which point to a particular row.
    2. If a bit is set to 1, it means that the associated row contains that value.
    3. The bit is associated with the ROWID of a row
    Each value contains a series of bits, each of which point to a particular row


Bitmap Indexes on Index-Organized Tables

A secondary index on an index-organized table can be a bitmap index. A bitmap index stores a bitmap for each index key. When bitmap indexes exist on an index-organized table, all the bitmap indexes use a heap-organized mapping table. The mapping table stores the logical rowids of the index-organized table. Each mapping table row stores one logical rowid for the corresponding index-organized table row. The database accesses a bitmap index using a search key. If the database finds the key, then the bitmap entry is converted to a physical rowid. With heap-organized tables, the database uses the physical rowid to access the base table. With index-organized tables, the database uses the physical rowid to access the mapping table, which in turn yields a logical rowid that the database uses to access the index-organized table. Figure 5-3 illustrates index access for a query of the departments_iot table.
Figure 5-3 Bitmap Index on index-organized Table
Figure 5-3: Bitmap Index on an index-organized table, which stores a bitmap for each index key

Bitmapped Index
Bitmap values green
Values and Bitmap

  1. Index values: Each value contains a series of bits, each of which point to a particular row.
  2. Bit values: If a bit is set to 1, it means that the associated row contains that value.
  3. Row: The bit is associated with the ROWID of a row.

Bitmapped indexes are not stored in sorted order, but they can be very powerful in data warehouse applications, where there are many selection conditions. Oracle can line up the bitmaps for each condition and quickly select the appropriate rows.

Oracle Index Types - Quiz

Click the quiz link below to answer a few questions about index types.
Index Types - Quiz
The next lesson shows how to create an index.
[1]low-cardinality columns: Low-cardinality columns in Oracle indexes are columns that have a relatively small number of distinct values. For example, a column that stores the gender of a customer might have only two possible values, male and female. This would be considered a low-cardinality column.

SEMrush Software 3 SEMrush Banner 3