- Reference >
- Database Commands >
- Administration Commands >
- collMod
collMod¶
On this page
Definition¶
Syntax¶
The command has the following syntax:
Note
Starting in MongoDB 4.2
For the <collection or view>, specify the name of a collection
or view in the current database.
Options¶
Index Options¶
- 
index¶
- The - indexoption can change the following properties of an existing index:- Index Property - Description - expireAfterSeconds- The 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 for- expireAfterSeconds
- expireAfterSeconds_old, the old value for- expireAfterSeconds, if the index had a value for- expireAfterSecondsbefore.
 - Modifying the index option - expireAfterSecondsresets the- $indexStatsfor the index.- hidden- A 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_oldand- hidden_new.- However, if the - hiddenvalue has not changed (i.e. hiding an already hidden index or unhiding an already unhidden index), the command omits the- hidden_oldand- hidden_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.- New in version 4.4. - prepareUnique- A boolean that determines whether the index will accept new duplicate entries. - New duplicate entries fail with DuplicateKey errors when - prepareUniqueis- true. The resulting index can be converted to a unique index. To convert the index, use- collModwith the- uniqueoption.- If an existing index is updated so that - prepareUniqueis- true, the index is not checked for pre-existing, duplicate index entries.- New in version 6.0. - unique- A boolean that determines whether or not the index is unique. - When - uniqueis- true,- collModscans the- keyPatternindex 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, - collModreturns- CannotConvertIndexToUniqueand a list of conflicting documents. To convert an index with duplicate entries to a unique index, correct any reported conflicts and rerun- collMod.- To end a conversion, set - prepareUniqueto- false.- New in version 6.0. - To change index options, specify either the key pattern or name of the existing index and the index option or options you wish to change: - If the index does not exist, the command errors with the message - "cannot find index <name|keyPattern> for ns <db.collection>".
Document Validation¶
- 
validator¶
- validatorallows 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.
 
- 
validationLevel¶
- The - validationLeveldetermines how strictly MongoDB applies the validation rules to existing documents during an update.- validationLevel- Description - "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. 
- 
validationAction¶
- The - validationActionoption determines whether to- erroron invalid documents or just- warnabout the violations but allow invalid documents.- Important - Validation of documents only applies to those documents as determined by the - validationLevel.- validationAction- Description - "error"- Default Documents must pass validation before the write occurs. Otherwise, the write operation fails. - "warn"- Documents do not have to pass validation. If the document fails validation, the write operation logs the validation failure. 
To view the validation specifications for a collection, use the
db.getCollectionInfos() method.
Views¶
Note
The view modified by this command does not refer to materialized
views. For discussion of on-demand materialized views, see
$merge instead.
- 
viewOn¶
- The 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. 
- 
pipeline¶
- The aggregation pipeline that defines the view. - Note - A view definition - pipelinecannot include the- $outor the- $mergestage. This restriction also applies to embedded pipelines, such as pipelines used in- $lookupor- $facetstages.- Required if modifying a view on a MongoDB deployment that is running with access control. - The view definition is public; i.e. - db.getCollectionInfos()and- explainoperations on the view will include the pipeline that defines the view. As such, avoid referring directly to sensitive fields and values in view definitions.
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:
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.
- 
cappedSize¶
- Specifies a new maximum size, in bytes, for a capped collection. - cappedSizemust be greater than- 0and less than- 1e+15(1 PB).
- 
cappedMax¶
- Specifies a new maximum number of documents in a capped collection. Setting - cappedMaxless than or equal to- 0implies 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:
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:
To enable change stream pre- and post-images for a collection, set
changeStreamPreAndPostImages to true. For example:
To disable change stream pre- and post-images for a collection, set
changeStreamPreAndPostImages to false. For example:
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 - expireAfterSecondsto- 100seconds:
- The following example returns the current - changeStreamOptionssettings, including- expireAfterSeconds:
- Setting - expireAfterSecondsto- offuses 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 megabytes. 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 megabytes if other change stream event fields like
updateDescriptionare not large.
- Request only pre-images in the change stream output for documents up
to 16 megabytes 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.
 
 
- 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
- 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.
 
- The 
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.
See also
- 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.
Write Concern¶
Optional. A document expressing the write concern of the drop 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 | collModin the database | 
| Modify a view | 
 | 
The built-in role dbAdmin provides the required privileges.
Behavior¶
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).
If successful, the operation returns a document that includes both the old and new value for the changed property:
Hide an Index from the Query Planner¶
Note
To hide an index, you must have featureCompatibilityVersion set to 4.4 or greater. However, once hidden, the
index remains hidden even with featureCompatibilityVersion set to 4.2 on MongoDB 4.4 binaries.
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.
If successful, the operation returns a document that includes both the old and new value for the changed property:
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.
Add Document Validation to an Existing Collection¶
The following example adds a validator to an existing collection named
contacts.
Note
MongoDB 3.6 adds the $jsonSchema operator to support JSON
Schema validation.
With the moderate validationLevel, MongoDB applies
validation rules to insert operations and to update operationss to
existing documents that already fulfill the validation criteria.
Updates to existing documents that do not fulfill the validation
criteria are not checked for validity.
With the warn validationAction, MongoDB logs any
violations but allows the insertion or update to proceed.
For example, the following insert operation violates the validation rule.
However, since the validationAction is warn only, MongoDB only
logs the validation violation message and allows the operation to
proceed:
For more information, see Schema Validation.
Convert an Existing Index to a Unique Index¶
Create the apples collection:
Add a single field index on type:
Prepare the index on the type field for conversion:
The existing index may contain duplicate entries, but it will not
accept new documents that duplicate an index entry when
prepareUnique is true.
Try to insert a document with a duplicate index value:
The operation returns an error. The index will not accept new duplicate entries.
Use the unique``option to convert the index to a unique index.
``collMod checks the collection for duplicate index entries before
converting the index:
The response to this operation varies by driver. You will always receive an error message about the duplicate entries.
Some drivers also return a list of ObjectIds for the duplicate
entries:
To complete the conversion, modify the duplicate entries to remove any
conflicts and re-run collMod() with the unique option.