You are viewing an offline version of MongoDB documentation. Some page features might be unavailable. To view the latest version of the page or use interactive features, visit the live page.
Build Materialized Views on Top of Time Series Data
Materialized views on time series data are useful for:
- archiving 
- analytics 
- facilitating data access for teams that cannot access the raw data 
To create an On-Demand Materialized view, use the $merge aggregation
pipeline stage to transform and store your data:
db.weather.aggregate([   {      $project: {         date: {            $dateToParts: { date: "$timestamp" }         },         temp: 1      }   },   {      $group: {         _id: {            date: {               year: "$date.year",               month: "$date.month",               day: "$date.day"            }         },         avgTmp: { $avg: "$temp" }      }   }, {      $merge: { into: "dailytemperatureaverages", whenMatched: "replace" }   } ]) 
The preceding pipeline, will create or update the
dailytemperatureaverages collection with all daily temperature
averages based on the weather collection.
Note
It is not possible to natively schedule the refreshing of these materialized views.
For more information on materialized views, see On-Demand Materialized Views.