Definition
collModcollModmakes it possible to add options to a collection or to modify view definitions.Tip
In
mongosh, this command can also be run through thehideIndex()andunhideIndex()helper methods.Helper methods are convenient for
mongoshusers, but they may not return the same level of information as database commands. In cases where the convenience is not needed or the additional return fields are required, use the database command.Note
The view modified by this command does not refer to materialized views. For discussion of on-demand materialized views, see
$mergeinstead.
Compatibility
This command is available in deployments hosted in the following environments:
MongoDB Atlas: The fully managed service for MongoDB deployments in the cloud
Note
This command is supported in all MongoDB Atlas clusters. For information on Atlas support for all commands, see Unsupported Commands.
MongoDB Enterprise: The subscription-based, self-managed version of MongoDB
MongoDB Community: The source-available, free-to-use, and self-managed version of MongoDB
Syntax
The command has the following syntax:
Note
Starting in MongoDB 4.2
db.runCommand( { collMod: <collection or view>, <option1>: <value1>, <option2>: <value2>, ... } )
For the <collection or view>, specify the name of a collection or view in the current database.
Options
Index Options
To change index options, specify either the key pattern or name of the existing index options you want to change:
db.runCommand( { collMod: <collection>, index: { keyPattern: <index_spec> | name: <index_name>, expireAfterSeconds: <number>, // Set the TTL expiration threshold hidden: <boolean>, // Change index visibility in the query planner prepareUnique: <boolean>, // Reject new duplicate index entries unique: <boolean> // Convert an index to a unique index }, dryRun: <boolean> } )
If the index does not exist, the command errors with the message "cannot find index <name|keyPattern> for ns <db.collection>".
indexThe
indexoption can change the following properties of an existing index:Index PropertyDescriptionexpireAfterSecondsThe number of seconds that determines the expiration threshold of a TTL Collection.
If successful, the command returns a document that contains:
expireAfterSeconds_new, the new value forexpireAfterSecondsexpireAfterSeconds_old, the old value forexpireAfterSeconds, if the index had a value forexpireAfterSecondsbefore.
Modifying the index option
expireAfterSecondsresets the$indexStatsfor the index.If you use TTL indexes created before MongoDB 5.0, or if you want to sync data created in MongDB 5.0 with a pre-5.0 installation, see Indexes Configured Using NaN to avoid misconfiguration issues.
The TTL index
expireAfterSecondsvalue must be within0and2147483647inclusive.hiddenA boolean that determines whether the index is hidden or not from the query planner.
If the
hiddenvalue changes, the command returns a document that contains both the old and new values for the changed property:hidden_oldandhidden_new.However, if the
hiddenvalue has not changed (i.e. hiding an already hidden index or unhiding an already unhidden index), the command omits thehidden_oldandhidden_newfields from the output.To hide an index, you must have featureCompatibilityVersion set to
4.4or greater.Modifying the index option
hiddenresets the$indexStatsfor the index if the value changes.prepareUniqueA boolean that determines whether the index will accept new duplicate entries.
New duplicate entries fail with DuplicateKey errors when
prepareUniqueistrue. The resulting index can be converted to a unique index. To convert the index, usecollModwith theuniqueoption.If an existing index is updated so that
prepareUniqueistrue, the index is not checked for pre-existing, duplicate index entries.New in version 6.0.
uniqueA boolean that determines whether the index is unique.
A value of
falseis not supported.When
uniqueistrue,collModscans thekeyPatternindex for duplicates and then converts it to a unique index if there are no duplicate index entries.If duplicates are detected during the initial scan,
collModreturnsCannotConvertIndexToUniqueand a list of conflicting documents. To convert an index with duplicate entries to a unique index, correct any reported conflicts and reruncollMod.To end a conversion, set
prepareUniquetofalse.To see an example of how to convert a non-unique index to a unique index, see Convert an Existing Index to a Unique Index.
New in version 6.0.
dryRunDefault value:
falseOnly used when
index.uniqueistrue.Before you convert a non-unique index to a unique index, you can run the
collModcommand withdryRun: true. If you do, MongoDB checks the collection for duplicate keys and returns any violations.Use
dryRun: trueto confirm that you can convert an index to be unique without any errors.
Document Validation
validatorvalidatorallows users to specify validation rules or expressions for a collection. For more information, see Schema Validation.The
validatoroption takes a document that specifies the validation rules or expressions. You can specify the expressions using the same operators as the query operators with the exception of$near,$nearSphere,$text, and$where.Note
Validation occurs during updates and inserts. Existing documents do not undergo validation checks until modification.
You cannot specify a validator for collections in the
admin,local, andconfigdatabases.You cannot specify a validator for
system.*collections.
validationLevelThe
validationLeveldetermines how strictly MongoDB applies the validation rules to existing documents during an update."off"- No validation for inserts or updates.
"strict"- Default Apply validation rules to all inserts and all updates.
"moderate"- Apply validation rules to inserts and to updates on existing valid documents. Do not apply rules to updates on existing invalid documents.
To see an example that uses
validationLevel, see Specify Validation Level for Existing Documents.
validationActionThe
validationActionoption determines whether toerroron invalid documents or justwarnabout the violations but allow invalid documents.Important
Validation of documents only applies to those documents as determined by the
validationLevel.To see an example that uses
validationAction, see Choose How to Handle Invalid Documents.
Views
Note
The view modified by this command does not refer to materialized views. For discussion of on-demand materialized views, see $merge instead.
viewOnThe underlying source collection or view for the view. The view definition is determined by applying the specified
pipelineto this source.Required if modifying a view on a MongoDB deployment that is running with access control.
pipelineThe aggregation pipeline that defines the view.
Note
Required if modifying a view on a MongoDB deployment that is running with access control.
The view definition is public; i.e.
db.getCollectionInfos()andexplainoperations on the view will include the pipeline that defines the view. As such, avoid referring directly to sensitive fields and values in view definitions.
db.runCommand( { collMod: "myView", viewOn: "activities", pipeline: [ { $match: { status: "Q" } }, { $project: { user: 1, date: 1, description: 1} } ] } )
Time Series Collections
To enable automatic removal of documents or change the expireAfterSeconds parameter value for an existing time series collection, issue the following collMod command:
db.runCommand( { collMod: <collection>, expireAfterSeconds: <Number> || "off" } )
The expireAfterSeconds field must be either:
A non-negative decimal number (
>=0)The string
"off".
A number specifies the number of seconds after which documents expire. The string "off" removes the expireAfterSeconds parameter and disables automatic removal.
Resize a Capped Collection
New in version 6.0.
Starting in MongoDB 6.0, you can resize a capped collection. To change a capped collection's maximum size in bytes, use the cappedSize option. To change the maximum number of documents in an existing capped collection, use the cappedMax option.
Note
You can't use these commands to resize the oplog. Use replSetResizeOplog instead.
cappedSizeSpecifies a new maximum size, in bytes, for a capped collection.
cappedSizemust be greater than0and less than1e+15(1 PB).
cappedMaxSpecifies a new maximum number of documents in a capped collection. Setting
cappedMaxless than or equal to0implies no limit.
For example, the following command sets the maximum size of a capped collection to 100000 bytes and sets the maximum number of documents in the collection to 500:
db.runCommand( { collMod: <collection>, cappedSize: 100000, cappedMax: 500 } )
Change Streams with Document Pre- and Post-Images
Starting in MongoDB 6.0, you can use change stream events to output the version of a document before and after changes (the document pre- and post-images):
The pre-image is the document before it was replaced, updated, or deleted. There is no pre-image for an inserted document.
The post-image is the document after it was inserted, replaced, or updated. There is no post-image for a deleted document.
Enable
changeStreamPreAndPostImagesfor a collection usingdb.createCollection(),create, orcollMod.
To use collMod to enable change stream pre- and post-images for a collection, use the changeStreamPreAndPostImages field:
db.runCommand( { collMod: <collection>, changeStreamPreAndPostImages: { enabled: <boolean> } } )
To enable change stream pre- and post-images for a collection, set changeStreamPreAndPostImages to true. For example:
db.runCommand( { collMod: "orders", changeStreamPreAndPostImages: { enabled: true } } )
To disable change stream pre- and post-images for a collection, set changeStreamPreAndPostImages to false. For example:
db.runCommand( { collMod: "orders", changeStreamPreAndPostImages: { enabled: false } } )
Pre- and post-images are not available for a change stream event if the images were:
Not enabled on the collection at the time of a document update or delete operation.
Removed after the pre- and post-image retention time set in
expireAfterSeconds.The following example sets
expireAfterSecondsto100seconds on an entire cluster:use admin db.runCommand( { setClusterParameter: { changeStreamOptions: { preAndPostImages: { expireAfterSeconds: 100 } } } } ) The following example returns the current
changeStreamOptionssettings, includingexpireAfterSeconds:db.adminCommand( { getClusterParameter: "changeStreamOptions" } ) Setting
expireAfterSecondstooffuses the default retention policy: pre- and post-images are retained until the corresponding change stream events are removed from the oplog.If a change stream event is removed from the oplog, then the corresponding pre- and post-images are also deleted regardless of the
expireAfterSecondspre- and post-image retention time.
Additional considerations:
Enabling pre- and post-images consumes storage space and adds processing time. Only enable pre- and post-images if you need them.
Limit the change stream event size to less than 16 mebibytes. To limit the event size, you can:
Limit the document size to 8 megabytes. You can request pre- and post-images simultaneously in the change stream output if other change stream event fields like
updateDescriptionare not large.Request only post-images in the change stream output for documents up to 16 mebibytes if other change stream event fields like
updateDescriptionare not large.Request only pre-images in the change stream output for documents up to 16 mebibytes if:
document updates affect only a small fraction of the document structure or content, and
do not cause a
replacechange event. Areplaceevent always includes the post-image.
To request a pre-image, you set
fullDocumentBeforeChangetorequiredorwhenAvailableindb.collection.watch(). To request a post-image, you setfullDocumentusing the same method.Pre-images are written to the
config.system.preimagescollection.The
config.system.preimagescollection may become large. To limit the collection size, you can setexpireAfterSecondstime for the pre-images as shown earlier.Pre-images are removed asynchronously by a background process.
Important
Backward-Incompatible Feature
Starting in MongoDB 6.0, if you are using document pre- and post-images for change streams, you must disable changeStreamPreAndPostImages for each collection using the collMod command before you can downgrade to an earlier MongoDB version.
Tip
For change stream events and output, see Change Events.
To watch a collection for changes, see
db.collection.watch().For complete examples with the change stream output, see Change Streams with Document Pre- and Post-Images.
Attach Comment
Optional. You can attach a comment to this command. The comment must be a top-level field and can be any valid BSON type. The comment that you specify appears alongside records of this command in the following locations:
mongod log messages, in the
attr.command.cursor.commentfield.Database profiler output, in the
command.commentfield.currentOpoutput, in thecommand.commentfield.
Write Concern
Optional. A document expressing the write concern of the collMod command.
Omit to use the default write concern.
Access Control
If the deployment enforces authentication/authorization, you must have the following privilege to run the collMod command:
Task | Required Privileges |
|---|---|
Modify a non-capped collection |
|
Modify a view |
The built-in role dbAdmin provides the required privileges.
Behavior
Resource Locking
The collMod command obtains a collection lock on the specified collection for the duration of the operation.
Examples
Change Expiration Value for Indexes
The following example updates the expireAfterSeconds property of an existing TTL index { lastAccess: 1 } on a collection named user_log. The current expireAfterSeconds property for the index is set to 1800 seconds (or 30 minutes) and the example changes the value to 3600 seconds (or 60 minutes).
db.runCommand({ collMod: "user_log", index: { keyPattern: { lastAccess: 1 }, expireAfterSeconds: 3600 } })
If successful, the operation returns a document that includes both the old and new value for the changed property:
{ "expireAfterSeconds_old" : 1800, "expireAfterSeconds_new" : 3600, "ok" : 1 }
Hide an Index from the Query Planner
Note
To hide an index, you must have featureCompatibilityVersion set to 5.0 or greater.
The following example hides an existing index on the orders collection. Specifically, the operation hides the index with the specification { shippedDate: 1 } from the query planner.
db.runCommand({ collMod: "orders", index: { keyPattern: { shippedDate: 1 }, hidden: true } })
If successful, the operation returns a document that includes both the old and new value for the changed property:
{ "hidden_old" : false, "hidden_new" : true, "ok" : 1 }
Note
If the operation is successful but the hidden value has not changed (i.e. hiding an already hidden index or unhiding an already unhidden index), the command omits the hidden_old and hidden_new fields from the output.
To hide a text index, you must specify the index by name and not by keyPattern.