Indexes in tables
Table indexes allow you query columns outside the table’s primary key.
Querying a non-indexed column either fails or triggers allow filtering, which is the least efficient way to query a table. Allow filtering can be slow and expensive, especially on large tables.
In contrast, querying on the primary key is the most efficient way to search. Indexes are not as performant as primary key queries, but they are much more performant than allow filtering.
The Data API supports the following index types:
- 
Regular indexes: Creating a regular index on a non- vectorcolumn allows you to run queries against the column.
- 
Text indexes: Creating a text index on a textorasciicolumn allows you to perform lexicographical matching on the column.
- 
Vector indexes: Creating a vector index on a vectorcolumn allows you to perform vector searches on the column.
You can only have one index per column. For example, you can’t have both a regular index and a text index on the same column.
Regular indexes
You should create a regular index on any non-vector column that you want to query.
For more information, see Create an index.
Index options for text and ASCII types
When creating a regular index on a text or ascii column, you can specify the following options:
- 
ASCII: Whether to convert non-ASCII characters to their US-ASCII equivalent before indexing. The default is false. This option can improve search performance by limiting the range of allowed ASCII characters. This option is best for ASCII-only data or ASCII-only applications where you can safely ignore non-ASCII characters. It is not recommended for multilingual data or applications that must support non-ASCII characters. If true, then alphabetic, numeric, and symbolic characters that are not in the Basic Latin Unicode block (the first 127 ASCII characters) are converted to the ASCII equivalent, if one exists. For example, àis indexed asa, and searches usingacan matchà. Characters with no equivalent are ignored.
- 
Normalize: Whether to normalize Unicode characters and diacritics before indexing. The default is false. This option can improve search consistency and inclusivity by normalizing Unicode characters, such as accented characters and diacritical marks that have multiple Unicode representations. This option is best for data sets that can contain multiple Unicode versions of the same character, such as multilingual data or non-standardized user input. If true, multiple versions of a Unicode character are normalized to a single version while retaining all marks and symbols in the index. For example, Å (U+212B)normalizes toÅ (U+00C5).
- 
Case sensitive: Whether the index is case sensitive. The default is true. This option enforces case sensitivity in searches. It is best for data sets where you want to enforce exact matches based on capitalization. If true, indexing and searches are case sensitive and honor capitalization. If false, indexing and searches are case insensitive and ignore capitalization. 
Index options for map types
When creating a regular index on a map column, you can index the entries, only the keys, or only the values. For examples, see Create an index for a map column.
Text indexes
You should create a text index on any text or ascii column on which you want to perform lexicographical matching.
For more information, see Create a text index.
When you create a text index, you can specify the analyzer to use.
Vector indexes
You should create a vector index on any vector column that you want to use in a vector search.
For more information, see Create a vector index.
When you create a vector index, you can specify the similarity metric to use for vector searches. You can also specify the source model for your vectors to enable certain vector optimizations on the index.
See also
For information about indexing in dynamic schema collections instead of in tables, see Indexes in collections.
