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-vector column allows you to run queries against the column.

  • Text indexes: Creating a text index on a text or ascii column allows you to perform lexicographical matching on the column.

  • Vector indexes: Creating a vector index on a vector column 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 as a, and searches using a can 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.

Was this helpful?

Give Feedback

How can we improve the documentation?

© 2025 DataStax, an IBM Company | Privacy policy | Terms of use | Manage Privacy Choices

Apache, Apache Cassandra, Cassandra, Apache Tomcat, Tomcat, Apache Lucene, Apache Solr, Apache Hadoop, Hadoop, Apache Pulsar, Pulsar, Apache Spark, Spark, Apache TinkerPop, TinkerPop, Apache Kafka and Kafka are either registered trademarks or trademarks of the Apache Software Foundation or its subsidiaries in Canada, the United States and/or other countries. Kubernetes is the registered trademark of the Linux Foundation.

General Inquiries: +1 (650) 389-6000, info@datastax.com