16.10 - Overview - Teradata Database

Teradata Database Design

Product
Teradata Database
Release Number
16.10
Release Date
June 2017
Content Type
User Guide
Publication ID
B035-1094-161K
Language
English (United States)

This chapter describes Teradata Database Unique Secondary Indexes (USIs) and Nonunique Secondary Indexes (NUSIs).

When column demographics suggest their usefulness, the Optimizer selects secondary indexes to provide faster single row or set selection, depending on whether the index is a USI or a NUSI, respectively.

A secondary index is never required for Teradata Database tables, but they can often improve system performance, particularly in decision support environments.

While secondary indexes are useful for optimizing repetitive and standardized queries, Teradata Database is also highly optimized to perform full-table scans in parallel. Because of the strength of full-table scan optimization in Teradata Database, there is little reason to be heavy-handed about assigning multiple secondary indexes to a table.

You can create secondary indexes when you create the table (see “CREATE TABLE” in SQL Data Definition Language), or you can add them later using the CREATE INDEX statement (see “CREATE INDEX” in SQL Data Definition Language). Unlike primary indexes, secondary indexes can be dropped and created at will without altering the table they index.

You can define a secondary index on a row-level security-protected column.

Data access using a secondary index varies depending on whether the index is unique or nonunique.

For more information about how Teradata Database accesses data using a unique secondary index, see USI Access.

For more information about how Teradata Database accesses data using a nonunique secondary index, see NUSI Access and Performance.

For design issues related to secondary index support for tactical queries, see Two-AMP Operations: USI Access and Tactical Queries and NUSI Access and Tactical Queries.

As is true for other types of indexes, you should keep the statistics on your secondary indexes as current as possible.

The recommended practice for recollecting statistics is to set appropriate thresholds for recollection using the THRESHOLD options of the COLLECT STATISTICS statement. See “COLLECT STATISTICS in SQL Data Definition Language for details on how to do this.