Views (original) (raw)

A MongoDB view is a read-only queryable object whose contents are defined by an aggregation pipeline on other collections or views.

MongoDB does not persist the view contents to disk. A view's content is computed on-demand when a client queries the view.

Note

Disambiguation

This page discusses standard views. For discussion of on-demand materialized views, see On-Demand Materialized Views.

To understand the differences between the view types, seeComparison with On-Demand Materialized Views.

You can use views to:

To learn how to create and manage views, see the following resources:

MongoDB provides two different view types: standard views andon-demand materialized views. Both view types return the results from an aggregation pipeline.

Note

When using $merge, you can use change streams to watch for changes on the materialized view. When using $out, you can't watch for changes on the materialized view.

Standard views use the indexes of the underlying collection. As a result, you cannot create, drop or re-build indexes on a standard view directly, nor get a list of indexes on the view.

You can create indexes directly on on-demand materialized views because they are stored on disk.

On-demand materialized views provide better read performance than standard views because they are read from disk instead of computed as part of the query. This performance benefit increases based on the complexity of the pipeline and size of the data being aggregated.

The following sections describe behavior specific to views.

Views are read-only. Write operations on views return an error.

Views do not maintain timestamps of collection changes and do not support point-in-time or snapshot read isolation.

The view's underlying aggregation pipeline is subject to the 100 megabyte memory limit for blocking sort and blocking group operations.

Starting in MongoDB 6.0, pipeline stages that require more than 100 megabytes of memory to execute write temporary files to disk by default. These temporary files last for the duration of the pipeline execution and can influence storage space on your instance. In earlier versions of MongoDB, you must pass { allowDiskUse: true } to individual find and aggregate commands to enable this behavior.

Individual find and aggregate commands can override theallowDiskUseByDefault parameter by either:

Note

For MongoDB Atlas, it is recommended toconfigure storage auto-scaling to prevent long-running queries from filling up storage with temporary files.

If your Atlas cluster uses storage auto-scaling, the temporary files may cause your cluster to scale to the next storage tier.

Warning

Do not attempt to create a time series collection or view with the name system.profile. MongoDB 6.3 and later versions return anIllegalOperation error if you attempt to do so. Earlier MongoDB versions crash.

If the deployment enforces authentication:

A user with the built-in readWrite role on the database has the required privileges to run the listed operations. To grant the required permissions, either: