This page describes the MongoDB aggregation pipeline stages and operators that Atlas Data Federation supports.
Note
By default, Atlas Data Federation does not return documents in any specific order
for queries on Data Federations for S3 data stores. Atlas Data Federation reads the
partitions concurrently and the underlying storage response order
determines which documents Atlas Data Federation returns first, unless you define
order using $sort in your query. For example, if you run
the same findOne() query twice, you could see different documents,
and if you use $skip, different documents might be skipped
if $sort is not used in the query.
Supported and Unsupported Aggregation Pipeline Stages
Atlas Data Federation supports all the aggregation pipeline stages except the following:
For the following stages in Atlas Data Federation queries, Atlas Data Federation introduces an alternate syntax, includes a caveat, or deviates from server. See the Description column for details.
| Pipeline Stage | Description | ||||||||
|---|---|---|---|---|---|---|---|---|---|
| Groups input documents by the specified  For example, the following is not supported:  | |||||||||
| Performs a left outer join to a collection in the same database.
Atlas Data Federation provides syntax for joining collections from different
databases also. See  | |||||||||
| Filters the documents to pass only the documents that match the
specified conditions to the next pipeline stage. Atlas Data Federation
supports  | |||||||||
| Writes the results of the aggregation pipeline to a specified collection.
Atlas Data Federation provides alternate syntax for the required  | |||||||||
| Takes the documents returned by the aggregation pipeline and writes them to a specified collection. Atlas Data Federation provides alternate syntax for writing to S3 and Atlas cluster. To use $out to write to a collection in a different database on the same Atlas cluster, your Atlas cluster must be on MongoDB version 7.0 or later. See $out for more information. | |||||||||
| Randomly selects the specified number of documents from its
input. Atlas Data Federation supports  | |||||||||
| Skips over the specified number of documents that pass into the
stage and passes the remaining documents to the next stage in
the pipeline. Atlas Data Federation supports  | 
Supported Aggregation Pipeline Operators
Atlas Data Federation supports all the aggregation pipeline operators. However, some operators are only available in queries on collections that are mapped to an Atlas cluster data store. The geospatial query operators are only available in such queries. The following evaluation query operators are also restriced to queries on collections mapped to an Atlas cluster data store:
| Pipeline Stage | Description | 
|---|---|
| Outputs documents in order of nearest to farthest from a
specified point. Atlas Data Federation supports  See Querying Data in Your Atlas Cluster for more information. | |
| Performs a recursive search on a collection. Atlas Data Federation supports
 
 See Querying Data in Your Atlas Cluster for more information. | |
| Performs a full-text search on the content of the fields covered by a MongoDB Search index. | |
| Performs a text search on the content of the fields indexed with a text index. | |
| Passes either a string containing a JavaScript expression or a full JavaScript function to the query system. | 
Note
Atlas Data Federation doesn't include a server-side JavaScript engine. So, Atlas Data Federation doesn't support operators such as $where, $function, and $accumulator that require server-side scripting enabled.