$setField (aggregation)
Definition
- $setField
- New in version 5.0. - Adds, updates, or removes a specified field in a document. - You can use - $setFieldto add, update, or remove fields with names that contain periods (- .) or start with dollar signs (- $).- Tip- Use - $getFieldto retrieve the values of fields that contain dollar signs (- $) or periods (- .) that you add or update with- $setField.
Syntax
$setField has the following syntax:
{   $setField: {     field: <String>,     input: <Object>,     value: <Expression>   } } 
You must provide the following fields:
| Field | Type | Description | 
|---|---|---|
| 
 | String | Field in the  | 
| 
 | Object | Document that contains the  | 
| 
 | Expression | The value that you want to assign to  Set to  | 
Behavior
- If - inputevaluates to- missing,- undefined, or- null,- $setFieldreturns- nulland does not update- input.
- If - inputevaluates to anything other than an object,- missing,- undefined, or- null,- $setFieldreturns an error.
- If - fieldresolves to anything other than a string constant,- $setFieldreturns an error.
- If - fielddoesn't exist in- input,- $setFieldadds it.
- $setFielddoesn't implicitly traverse objects or arrays. For example,- $setFieldevaluates a- fieldvalue of- "a.b.c"as a top-level field- "a.b.c"instead of as a nested field,- { "a": { "b": { "c": } } }.
- $unsetFieldis an alias for- $setFieldwith an input value of- $$REMOVE. The following expressions are equivalent:- { - $setField: { - field: <field name>, - input: “$$ROOT”, - value: "$$REMOVE" - } - } - { - $unsetField: { - field: <field name>, - input: “$$ROOT” - } - } 
See also:
Examples
Add Fields that Contain Periods (.)
Consider an inventory collection with the following documents:
db.inventory.insertMany( [    { "_id" : 1, "item" : "sweatshirt", price: 45.99, qty: 300 }    { "_id" : 2, "item" : "winter coat", price: 499.99, qty: 200 }    { "_id" : 3, "item" : "sun dress", price: 199.99, qty: 250 }    { "_id" : 4, "item" : "leather boots", price: 249.99, qty: 300 }    { "_id" : 5, "item" : "bow tie", price: 9.99, qty: 180 } ] ) 
The following operation uses the $replaceWith pipeline stage
and the $setField operator to add a new field to each
document, "price.usd". The value of "price.usd" will equal the
value of "price" in each document. Finally, the operation uses the
$unset pipeline stage to remove the "price" field.
db.inventory.aggregate( [    { $replaceWith: {         $setField: {            field: "price.usd",            input: "$$ROOT",            value: "$price"    } } },    { $unset: "price" } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300, 'price.usd': 45.99 },   { _id: 2, item: 'winter coat', qty: 200, 'price.usd': 499.99 },   { _id: 3, item: 'sun dress', qty: 250, 'price.usd': 199.99 },   { _id: 4, item: 'leather boots', qty: 300, 'price.usd': 249.99 },   { _id: 5, item: 'bow tie', qty: 180, 'price.usd': 9.99 } ] 
Add Fields that Start with a Dollar Sign ($)
Consider an inventory collection with the following documents:
db.inventory.insertMany( [    { "_id" : 1, "item" : "sweatshirt", price: 45.99, qty: 300 }    { "_id" : 2, "item" : "winter coat", price: 499.99, qty: 200 }    { "_id" : 3, "item" : "sun dress", price: 199.99, qty: 250 }    { "_id" : 4, "item" : "leather boots", price: 249.99, qty: 300 }    { "_id" : 5, "item" : "bow tie", price: 9.99, qty: 180 } ] ) 
The following operation uses the $replaceWith pipeline
stage and the $setField and $literal
operators to add a new field to each document, "$price". The value
of "$price" will equal the value of "price" in each document.
Finally, the operation uses the $unset pipeline stage to
remove the "price" field.
db.inventory.aggregate( [    { $replaceWith: {         $setField: {            field: { $literal: "$price" },            input: "$$ROOT",            value: "$price"    } } },    { $unset: "price" } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300, '$price': 45.99 },   { _id: 2, item: 'winter coat', qty: 200, '$price': 499.99 },   { _id: 3, item: 'sun dress', qty: 250, '$price': 199.99 },   { _id: 4, item: 'leather boots', qty: 300, '$price': 249.99 },   { _id: 5, item: 'bow tie', qty: 180, '$price': 9.99 } ] 
Update Fields that Contain Periods (.)
Consider an inventory collection with the following documents:
db.inventory.insertMany( [    { _id: 1, item: 'sweatshirt', qty: 300, 'price.usd': 45.99 },    { _id: 2, item: 'winter coat', qty: 200, 'price.usd': 499.99 },    { _id: 3, item: 'sun dress', qty: 250, 'price.usd': 199.99 },    { _id: 4, item: 'leather boots', qty: 300, 'price.usd': 249.99 },    { _id: 5, item: 'bow tie', qty: 180, 'price.usd': 9.99 } ] ) 
The following operation uses the $match pipeline stage to
find a specific document and the $replaceWith pipeline stage
and the $setField operator to update the "price.usd"
field in the matching document:
db.inventory.aggregate( [    { $match: { _id: 1 } },    { $replaceWith: {         $setField: {            field: "price.usd",            input: "$$ROOT",            value: 49.99     } } } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300, 'price.usd': 49.99 } ] 
Update Fields that Start with a Dollar Sign ($)
Consider an inventory collection with the following documents:
db.inventory.insertMany([    { _id: 1, item: 'sweatshirt', qty: 300, '$price': 45.99 },    { _id: 2, item: 'winter coat', qty: 200, '$price': 499.99 },    { _id: 3, item: 'sun dress', qty: 250, '$price': 199.99 },    { _id: 4, item: 'leather boots', qty: 300, '$price': 249.99 },    { _id: 5, item: 'bow tie', qty: 180, '$price': 9.99 } ] ) 
The following operation uses the $match pipeline stage to
find a specific document and the $replaceWith pipeline stage
and the $setField and $literal operators to
update the "$price" field in the matching document:
db.inventory.aggregate( [    { $match: { _id: 1 } },    { $replaceWith: {         $setField: {            field: { $literal: "$price" },            input: "$$ROOT",            value: 49.99    } } } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300, '$price': 49.99 } ] 
Remove Fields that Contain Periods (.)
Consider an inventory collection with the following documents:
db.inventory.insertMany([    { _id: 1, item: 'sweatshirt', qty: 300, 'price.usd': 45.99 },    { _id: 2, item: 'winter coat', qty: 200, 'price.usd': 499.99 },    { _id: 3, item: 'sun dress', qty: 250, 'price.usd': 199.99 },    { _id: 4, item: 'leather boots', qty: 300, 'price.usd': 249.99 },    { _id: 5, item: 'bow tie', qty: 180, 'price.usd': 9.99 } ] ) 
The following operation uses the $replaceWith pipeline stage
and the $setField operator and $$REMOVE to remove the "price.usd" field from each document:
db.inventory.aggregate( [    { $replaceWith:  {         $setField: {            field: "price.usd",            input: "$$ROOT",            value: "$$REMOVE"    } } } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300 },   { _id: 2, item: 'winter coat', qty: 200 },   { _id: 3, item: 'sun dress', qty: 250 },   { _id: 4, item: 'leather boots', qty: 300 },   { _id: 5, item: 'bow tie', qty: 180 } ] 
A similar query written using the $unsetField alias
returns the same results:
db.inventory.aggregate( [    { $replaceWith:  {         $unsetField: {            field: "price.usd",            input: "$$ROOT"    } } } ] ) 
Remove Fields that Start with a Dollar Sign ($)
Consider an inventory collection with the following documents:
db.inventory.insertMany( [    { _id: 1, item: 'sweatshirt', qty: 300, '$price': 45.99 },    { _id: 2, item: 'winter coat', qty: 200, '$price': 499.99 },    { _id: 3, item: 'sun dress', qty: 250, '$price': 199.99 },    { _id: 4, item: 'leather boots', qty: 300, '$price': 249.99 },    { _id: 5, item: 'bow tie', qty: 180, '$price': 9.99 } } ) 
The following operation uses the $replaceWith pipeline
stage, the $setField and $literal operators,
and $$REMOVE to remove the "$price" field
from each document:
db.inventory.aggregate( [    { $replaceWith: {         $setField: {            field: { $literal: "$price" },            input: "$$ROOT",            value: "$$REMOVE"    } } } ] ) 
The operation returns the following results:
[   { _id: 1, item: 'sweatshirt', qty: 300 },   { _id: 2, item: 'winter coat', qty: 200 },   { _id: 3, item: 'sun dress', qty: 250 },   { _id: 4, item: 'leather boots', qty: 300 },   { _id: 5, item: 'bow tie', qty: 180 } ] 
A similar query written using the $unsetField alias
returns the same results:
db.inventory.aggregate( [   { $replaceWith: {        $unsetField: {           field: { $literal: "$price" },           input: "$$ROOT"   } } } ] ) 
See also: