package model
The model package containing models and options that help describe MongoCollection operations
- Alphabetic
- By Inheritance
- model
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Package Members
-  package changestream
-    package densify- Since
- 4.7 
- Note
- Requires MongoDB 5.1 or greater. 
- See also
- Aggregates.densify
 
-    package fill- Since
- 4.7 
- Note
- Requires MongoDB 5.3 or greater. 
- See also
- Aggregates.fill
 
-  package geojson
-    package searchQuery building API for MongoDB Atlas full-text search. Query building API for MongoDB Atlas full-text search. While all the building blocks of this API, such as SearchOptions,SearchHighlight, etc., are not necessary immutable, they are unmodifiable due to methods likeSearchHighlight.maxCharsToExaminereturning new instances instead of modifying the instance on which they are called. This allows storing and using such instances as templates.- Since
- 4.7 
- See also
- Aggregates.search- Aggregates.vectorSearch
 
-    package vaultThis package contains options classes for the key vault API This package contains options classes for the key vault API - Since
- 2.7 
 
Type Members
-    type ApproximateQuantileMethod = com.mongodb.client.model.ApproximateQuantileMethod- Annotations
- @Sealed()
- See also
- QuantileMethod.approximate()
 
-    type BsonField = com.mongodb.client.model.BsonFieldA representation of a BSON document field whose value is another BSON document. 
-    type BucketAutoOptions = com.mongodb.client.model.BucketAutoOptionsThe options for a $bucketAutoaggregation pipeline stageThe options for a $bucketAutoaggregation pipeline stage- Since
- 1.2 
 
-    type BucketGranularity = com.mongodb.client.model.BucketGranularityGranularity values for automatic bucketing. Granularity values for automatic bucketing. - Since
- 1.2 
- See also
 
-    type BucketOptions = com.mongodb.client.model.BucketOptionsThe options for a $bucketaggregation pipeline stageThe options for a $bucketaggregation pipeline stage- Since
- 1.2 
 
-    type BulkWriteOptions = com.mongodb.client.model.BulkWriteOptionsThe options to apply to a bulk write. 
-    type ChangeStreamPreAndPostImagesOptions = com.mongodb.client.model.ChangeStreamPreAndPostImagesOptionsOptions for change stream pre- and post- images 
-    type ClusteredIndexOptions = com.mongodb.client.model.ClusteredIndexOptionsOptions for creating a clustered index on a collection 
-    type Collation = com.mongodb.client.model.CollationThe collation options. 
-    type CollationAlternate = com.mongodb.client.model.CollationAlternateThe collation alternative options. 
-    type CollationCaseFirst = com.mongodb.client.model.CollationCaseFirstThe collation configuration of how character cases are handled 
-    type CollationMaxVariable = com.mongodb.client.model.CollationMaxVariableThe collation max variable options 
-    type CollationStrength = com.mongodb.client.model.CollationStrengthThe collation configuration of how differences between characters are handled. 
-    type CountOptions = com.mongodb.client.model.CountOptionsThe options to apply to a count operation. 
-    type CreateCollectionOptions = com.mongodb.client.model.CreateCollectionOptionsOptions for creating a collection 
-    type CreateEncryptedCollectionParams = com.mongodb.client.model.CreateEncryptedCollectionParamsAuxiliary parameters for creating an encrypted collection. Auxiliary parameters for creating an encrypted collection. - Annotations
- @Beta()
- Since
- 4.9 
 
-    type CreateIndexOptions = com.mongodb.client.model.CreateIndexOptionsThe options to apply to the command when creating indexes. The options to apply to the command when creating indexes. - Since
- 2.2 
 
-    type CreateViewOptions = com.mongodb.client.model.CreateViewOptionsOptions for creating a view Options for creating a view - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    type DeleteManyModel[TResult] = com.mongodb.client.model.DeleteManyModel[TResult]A model describing the removal of all documents matching the query filter. 
-    type DeleteOneModel[TResult] = com.mongodb.client.model.DeleteOneModel[TResult]A model describing the removal of at most one document matching the query filter. 
-    type DeleteOptions = com.mongodb.client.model.DeleteOptionsThe options to apply for delete operations 
-    type DropCollectionOptions = com.mongodb.client.model.DropCollectionOptionsOptions for creating a collection Options for creating a collection - Since
- 4.6 
 
-    type DropIndexOptions = com.mongodb.client.model.DropIndexOptionsThe options to apply to the command when creating indexes. The options to apply to the command when creating indexes. - Since
- 2.2 
 
-    type EstimatedDocumentCountOptions = com.mongodb.client.model.EstimatedDocumentCountOptionsThe options to apply to an estimated count operation. The options to apply to an estimated count operation. - Since
- 2.4 
 
-    type Facet = com.mongodb.client.model.FacetDefines a Facet for use in $facetpipeline stages.Defines a Facet for use in $facetpipeline stages.- Since
- 1.2 
 
-    type Field[TExpression] = com.mongodb.client.model.Field[TExpression]A helper to define new fields for the $addFieldspipeline stageA helper to define new fields for the $addFieldspipeline stage- Since
- 1.2 
 
-    type FindOneAndDeleteOptions = com.mongodb.client.model.FindOneAndDeleteOptionsThe options to apply to an operation that atomically finds a document and deletes it. 
-    type FindOneAndReplaceOptions = com.mongodb.client.model.FindOneAndReplaceOptionsThe options to apply to an operation that atomically finds a document and replaces it. 
-    type FindOneAndUpdateOptions = com.mongodb.client.model.FindOneAndUpdateOptionsThe options to apply to an operation that atomically finds a document and updates it. 
-  type GeoNearOptions = com.mongodb.client.model.GeoNearOptions
-    type GraphLookupOptions = com.mongodb.client.model.GraphLookupOptionsThe options for a graphLookup aggregation pipeline stage The options for a graphLookup aggregation pipeline stage - Since
- 1.2 
 
-    type IndexModel = com.mongodb.client.model.IndexModelA model describing the creation of a single index. 
-    type IndexOptionDefaults = com.mongodb.client.model.IndexOptionDefaultsThe default options for a collection to apply on the creation of indexes. The default options for a collection to apply on the creation of indexes. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
- See also
 
-    type IndexOptions = com.mongodb.client.model.IndexOptionsThe options to apply to the creation of an index. 
-    type InsertManyOptions = com.mongodb.client.model.InsertManyOptionsThe options to apply to an operation that inserts multiple documents into a collection. 
-    type InsertOneModel[TResult] = com.mongodb.client.model.InsertOneModel[TResult]A model describing an insert of a single document. 
-    type InsertOneOptions = com.mongodb.client.model.InsertOneOptionsThe options to apply to an operation that inserts a single document into a collection. The options to apply to an operation that inserts a single document into a collection. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    type MapReduceAction = com.mongodb.client.model.MapReduceActionThe map reduce to collection actions. The map reduce to collection actions. These actions are only available when passing out a collection that already exists. This option is not available on secondary members of replica sets. The Enum values dictate what to do with the output collection if it already exists when the map reduce is run. 
-    case class MergeOptions(wrapped: com.mongodb.client.model.MergeOptions = new JMergeOptions()) extends Product with SerializableOptions to control the behavior of the $mergeaggregation stageOptions to control the behavior of the $mergeaggregation stage- Since
- 2.7 
 
-    type PushOptions = com.mongodb.client.model.PushOptionsThe options to apply to a $pushupdate operator.
-    type RenameCollectionOptions = com.mongodb.client.model.RenameCollectionOptionsThe options to apply when renaming a collection 
-    type ReplaceOneModel[TResult] = com.mongodb.client.model.ReplaceOneModel[TResult]A model describing the replacement of at most one document that matches the query filter. 
-    type ReplaceOptions = com.mongodb.client.model.ReplaceOptionsThe options to apply when replacing documents. The options to apply when replacing documents. - Since
- 2.3 
 
-    type ReturnDocument = com.mongodb.client.model.ReturnDocumentIndicates which document to return, the original document before change or the document after the change 
-    type SearchIndexModel = com.mongodb.client.model.SearchIndexModelA model describing the creation of a single Atlas Search index. 
-    type TextSearchOptions = com.mongodb.client.model.TextSearchOptionsText search options for the Filters text helper 
-    type TimeSeriesGranularity = com.mongodb.client.model.TimeSeriesGranularityEnumeration of values for time-series data granularity 
-    type TimeSeriesOptions = com.mongodb.client.model.TimeSeriesOptionsOptions for creating a time-series collection 
-    type UnwindOptions = com.mongodb.client.model.UnwindOptionsThe options for an unwind aggregation pipeline stage The options for an unwind aggregation pipeline stage - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    type UpdateManyModel[TResult] = com.mongodb.client.model.UpdateManyModel[TResult]A model describing an update to all documents that matches the query filter. A model describing an update to all documents that matches the query filter. The update to apply must include only update operators. 
-    type UpdateOneModel[TResult] = com.mongodb.client.model.UpdateOneModel[TResult]A model describing an update to at most one document that matches the query filter. A model describing an update to at most one document that matches the query filter. The update to apply must include only update operators. 
-    type UpdateOptions = com.mongodb.client.model.UpdateOptionsThe options to apply when updating documents. 
-    type ValidationAction = com.mongodb.client.model.ValidationActionDetermines whether to error on invalid documents or just warn about the violations but allow invalid documents. Determines whether to error on invalid documents or just warn about the violations but allow invalid documents. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    type ValidationLevel = com.mongodb.client.model.ValidationLevelDetermines how strictly MongoDB applies the validation rules to existing documents during an insert or update. Determines how strictly MongoDB applies the validation rules to existing documents during an insert or update. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    type ValidationOptions = com.mongodb.client.model.ValidationOptionsValidation options for documents being inserted or updated in a collection Validation options for documents being inserted or updated in a collection - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    type Variable[TExpression] = com.mongodb.client.model.Variable[TExpression]Helps define new variable for the $lookuppipeline stageHelps define new variable for the $lookuppipeline stage- Since
- 2.3 
 
-    type Window = com.mongodb.client.model.WindowA subset of documents within a partition in the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline (seepartitionByinAggregates.setWindowFields).A subset of documents within a partition in the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline (seepartitionByinAggregates.setWindowFields).- Since
- 4.3 
- See also
 
-    type WindowOutputField = com.mongodb.client.model.WindowOutputFieldThe core part of the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline.The core part of the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline. A triple of a window function, a window and a path to a field to be computed by the window function over the window.- Since
- 4.3 
- See also
 
-    type WriteModel[TResult] = com.mongodb.client.model.WriteModel[TResult]A base class for models that can be used in a bulk write operations. 
Value Members
-    object AccumulatorsBuilders for accumulators used in the group pipeline stage of an aggregation pipeline. Builders for accumulators used in the group pipeline stage of an aggregation pipeline. - Since
- 1.0 
- See also
 
-    object AggregatesBuilders for aggregation pipeline stages. Builders for aggregation pipeline stages. - Since
- 1.0 
- See also
 
-    object BsonFieldA representation of a BSON document field whose value is another BSON document. 
-    object BucketAutoOptionsThe options for a $bucketAutoaggregation pipeline stageThe options for a $bucketAutoaggregation pipeline stage- Since
- 1.2 
 
-    object BucketGranularityGranularity values for automatic bucketing. Granularity values for automatic bucketing. - Since
- 1.2 
- See also
 
-    object BucketOptionsThe options for a $bucketaggregation pipeline stageThe options for a $bucketaggregation pipeline stage- Since
- 1.2 
 
-    object BulkWriteOptionsThe options to apply to a bulk write. 
-    object ChangeStreamPreAndPostImagesOptionsOptions for change stream pre- and post- images 
-    object ClusteredIndexOptionsOptions for creating a clustered index on a collection 
-    object CollationThe options regarding collation support in MongoDB 3.4+ The options regarding collation support in MongoDB 3.4+ - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object CollationAlternateCollation support allows the specific configuration of whether or not spaces and punctuation are considered base characters. Collation support allows the specific configuration of whether or not spaces and punctuation are considered base characters. - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object CollationCaseFirstCollation support allows the specific configuration of how character cases are handled. Collation support allows the specific configuration of how character cases are handled. - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object CollationMaxVariableCollation support allows the specific configuration of whether or not spaces and punctuation are considered base characters. Collation support allows the specific configuration of whether or not spaces and punctuation are considered base characters. CollationMaxVariablecontrols which characters are affected by CollationAlternate$.SHIFTED.- Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object CollationStrengthCollation support allows the specific configuration of how character cases are handled. Collation support allows the specific configuration of how character cases are handled. - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object CountOptionsThe options to apply to a count operation. 
-    object CreateCollectionOptionsOptions for creating a collection 
-    object CreateEncryptedCollectionParamsAuxiliary parameters for creating an encrypted collection. Auxiliary parameters for creating an encrypted collection. - Annotations
- @Beta()
- Since
- 4.9 
 
-    object CreateViewOptionsOptions for creating a view Options for creating a view - Since
- 1.2 
- Note
- Requires MongoDB 3.4 or greater 
 
-    object DeleteManyModelA model describing the removal of all documents matching the query filter. 
-    object DeleteOneModelA model describing the removal of at most one document matching the query filter. 
-    object DeleteOptionsThe options to apply for delete operations. 
-    object DropCollectionOptionsOptions for creating a collection Options for creating a collection - Since
- 4.6 
 
-    object EstimatedDocumentCountOptionsThe options to apply to an estimated count operation. The options to apply to an estimated count operation. - Since
- 2.4 
 
-    object FacetDefines a Facet for use in $facetpipeline stages.Defines a Facet for use in $facetpipeline stages.- Since
- 1.2 
 
-    object FieldA helper to define new fields for the $addFieldspipeline stageA helper to define new fields for the $addFieldspipeline stage- Since
- 1.2 
 
-    object FiltersA factory for query filters. A factory for query filters. A convenient way to use this class is to statically import all of its methods, which allows usage like: collection.find(and(eq("x", 1), lt("y", 3)))- Since
- 1.0 
 
-    object FindOneAndDeleteOptionsThe options to apply to an operation that atomically finds a document and deletes it. 
-    object FindOneAndReplaceOptionsThe options to apply to an operation that atomically finds a document and replaces it. 
-    object FindOneAndUpdateOptionsThe options to apply to an operation that atomically finds a document and updates it. 
-    object GraphLookupOptionsThe options for a graphLookup aggregation pipeline stage The options for a graphLookup aggregation pipeline stage - Since
- 1.2 
 
-    object IndexModelA model describing the creation of a single index. 
-    object IndexOptionDefaultsOptions for creating an index 
-    object IndexOptionsThe options to apply to the creation of an index. 
-    object IndexesA factory for defining index keys. A factory for defining index keys. A convenient way to use this class is to statically import all of its methods, which allows usage like: collection.createIndex(compoundIndex(ascending("x"), descending("y"))) - Since
- 1.0 
 
-    object InsertManyOptionsThe options to apply to an operation that inserts multiple documents into a collection. 
-    object InsertOneModelA model describing an insert of a single document. 
-    object InsertOneOptionsThe options to apply to an operation that inserts a single document into a collection. The options to apply to an operation that inserts a single document into a collection. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    object MergeOptions extends SerializableOptions to control the behavior of the $mergeaggregation stageOptions to control the behavior of the $mergeaggregation stage- Since
- 2.7 
 
-    object MongoTimeUnitUnits for specifying time-based values. Units for specifying time-based values. - Since
- 4.3 
- Note
- Requires MongoDB 5.0 or greater. 
- See also
- org.mongodb.scala.model.densify.DensifyRange
 
-    object ProjectionsA factory for projections. A factory for projections. A convenient way to use this class is to statically import all of its methods, which allows usage like: collection.find().projection(fields(include("x", "y"), excludeId()))- Since
- 1.0 
 
-    object PushOptionsThe options to apply to a $pushupdate operator.
-    object QuantileMethodThis interface represents a quantile method used in quantile accumulators of the $groupand$setWindowFieldsstages.This interface represents a quantile method used in quantile accumulators of the $groupand$setWindowFieldsstages.It provides methods for creating and converting quantile methods to BsonValue.- Annotations
- @Sealed()
- Since
- 4.10 
- Note
- Requires MongoDB 7.0 or greater 
- See also
 
-    object RenameCollectionOptionsThe options to apply when renaming a collection 
-    object ReplaceOneModelA model describing the replacement of at most one document that matches the query filter. 
-    object ReplaceOptionsThe options to apply when replacing documents. The options to apply when replacing documents. - Since
- 2.3 
 
-    object ReturnDocumentIndicates which document to return, the original document before change or the document after the change Indicates which document to return, the original document before change or the document after the change - Since
- 1.0 
 
-    object SearchIndexModelA model describing the creation of a single Atlas Search index. 
-    object SortsA factory for sort specifications. A factory for sort specifications. A convenient way to use this class is to statically import all of its methods, which allows usage like: collection.find().sort(orderBy(ascending("x", "y"), descending("z")))- Since
- 1.0 
 
-    object TextSearchOptionsText search options for the Filters text helper Text search options for the Filters text helper - Since
- 1.1 
 
-    object TimeSeriesOptionsOptions for creating a time-series collection 
-    object UnwindOptionsThe options for an unwind aggregation pipeline stage The options for an unwind aggregation pipeline stage - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    object UpdateManyModelA model describing an update to all documents that matches the query filter. A model describing an update to all documents that matches the query filter. The update to apply must include only update operators. 
-    object UpdateOneModelA model describing an update to at most one document that matches the query filter. A model describing an update to at most one document that matches the query filter. The update to apply must include only update operators. 
-    object UpdateOptionsThe options to apply when updating documents. 
-    object UpdatesA factory for document updates. A factory for document updates. A convenient way to use this class is to statically import all of its methods, which allows usage like: collection.updateOne(eq("x", 1), set("x", 2))- Since
- 1.0 
 
-    object ValidationActionDetermines how strictly MongoDB applies the validation rules to existing documents during an insert or update. Determines how strictly MongoDB applies the validation rules to existing documents during an insert or update. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    object ValidationLevelDetermines how strictly MongoDB applies the validation rules to existing documents during an insert or update. Determines how strictly MongoDB applies the validation rules to existing documents during an insert or update. - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    object ValidationOptionsValidation options for documents being inserted or updated in a collection Validation options for documents being inserted or updated in a collection - Since
- 1.1 
- Note
- Requires MongoDB 3.2 or greater 
 
-    object VariableHelps define new variable for the $lookuppipeline stageHelps define new variable for the $lookuppipeline stage- Since
- 2.3 
 
-    object WindowOutputFieldsBuilders for window output fields used in the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline.Builders for window output fields used in the Aggregates.setWindowFieldspipeline stage of an aggregation pipeline. Each windowed output field is a triple:- A window function. Some functions require documents in a window to be sorted
 (see sortByinAggregates.setWindowFields).
- An optional window, a.k.a. frame.
   Specifying Nonewindow is equivalent to specifying an unbounded window, i.e., a window with both ends specified as UNBOUNDED. Some window functions, e.g., WindowOutputFields.derivative, require an explicit unbounded window instead ofNone.
- A path to an output field to be computed by the window function over the window.
 A windowed computation is similar to an accumulator but does not result in folding documents constituting the window into a single document. - Since
- 4.3 
- Note
- Requires MongoDB 5.0 or greater. 
- See also
 
- A window function. Some functions require documents in a window to be sorted
 (see 
-    object WindowsBuilders for windows used when expressing window output fields. Builders for windows used when expressing window output fields. There are two types of windows: documents and range. Bounded and half-bounded windows require sorting. Window bounds are inclusive and the lower bound must always be less than or equal to the upper bound. The following type-specific rules are applied to windows: - documents- bounds- 0 refers to the current document and is functionally equivalent to CURRENT;
- a negative value refers to documents preceding the current one;
- a positive value refers to documents following the current one;
 
 
- bounds
- range- sortBy(see- Aggregates.setWindowFields)- must contain exactly one field;
- must specify the ascending sort order;
- the sortByfield must be of either a numeric BSON type (see the$isNumberaggregation pipeline stage) or the BSONDatetype if time bounds are used;
 
- bounds- if numeric, i.e., not com.mongodb.client.model.Windows.Bound, then the bound is calculated by adding the value to the value of thesortByfield in the current document;
- if CURRENT, then the bound is determined by the current document
     and not the current value of the sortByfield;
- time bounds require specifying a time unit and are added as per the
     $dateAdd/$dateSubtractaggregation pipeline stage specification.
 
- if numeric, i.e., not 
 
 - Annotations
- @Beta()
- Since
- 4.3 
- Note
- Requires MongoDB 5.0 or greater. 
- See also
 
- documents
Deprecated Value Members
-    object MapReduceActionThe map reduce to collection actions. The map reduce to collection actions. These actions are only available when passing out a collection that already exists. This option is not available on secondary members of replica sets. The Enum values dictate what to do with the output collection if it already exists when the map reduce is run. - Annotations
- @deprecated
- Deprecated
- (Since version 4.4.0) Superseded by aggregate 
- Since
- 1.0 
 
This is the documentation for the MongoDB Scala driver.
Driver structure
The mongodb scala driver.
To get started you need a MongoClient instance, either from a connection string or via a org.mongodb.scala.MongoClientSettings.
Notable packages include: