Docs Menu
Docs Home
/
MongoDB Manual
/

Time Series Indexes

On this page

  • Clustered Collection
  • Compound Indexes
  • Partial Indexes
  • TTL Indexes
  • Prohibited Indexes
  • Indexing Best Practices

Indexes on time series collections generally behave like indexes on regular collections, but with several additional considerations and limitations.

If there are secondary indexes on time series collections and you need to downgrade the feature compatibility version (FCV), you must first drop any secondary indexes that are incompatible with the downgraded FCV. For more information, see setFeatureCompatibilityVersion.

Starting in version 6.0, you can add a secondary index to any field in a time series collection. MongoDB indexes time series collections by buckets of documents as opposed to individual documents. Time series buckets contain documents with shared metaField values, ordered by timeField values that are close together. MongoDB indexes the minimum and maximum values of all fields, except the metaField. Indexing buckets instead of individual documents reduces index size and improves query efficiency.

Tip

To improve query performance, you can manually add secondary indexes any field in your time series collection.

By default, MongoDB clusters time series collections based on bucket time.

New in version 6.3.

Starting in MongoDB 6.3, MongoDB creates a default compound index on both the metaField and timeField of a time series collection. MongoDB uses this index to improve query performance and speed.

You can add a compound index on the timeField, metaField, or measurement fields.

New in version 6.0.

Starting in MongoDB 6.0, you can use the $or, $in, and $geoWithin operators with partial indexes on a time series collection.

You cannot create partial indexes on the metaField and timeField.

New in version 6.3.

Starting in MongoDB 6.3, you can create a TTL index with a partialFilterExpression that relies only on the metaField. In versions prior to 6.3, you can only create TTL indexes based on the expireAfterSeconds parameter.

If your time series collection doesn't use the expireAfterSeconds option to expire documents, creating a partial TTL index sets an expiration time for matching documents only. If the collection uses expireAfterSeconds for all documents, you can use a partial TTL index to expire matching documents sooner.

MongoDB does not allow the following index types on time series collections:

You cannot create sparse indexes on the metaField.

  • Use the metaField index for filtering and equality.

  • Use the timeField and other indexed fields for range queries.

  • General indexing strategies also apply to time series collections. For more information, see Indexing Strategies.

For more information and examples, see Add Secondary Indexes to Time Series Collections.

Back

Build Materialized Views