You are viewing an offline version of MongoDB documentation. Some page features might be unavailable. To view the latest version of the page or use interactive features, visit the live page.
$cmp (aggregation)
Definition
- $cmp
- Compares two values and returns: - -1if the first value is less than the second.
- 1if the first value is greater than the second.
- 0if the two values are equivalent.
 - The - $cmpcompares both value and type, using the specified BSON comparison order for values of different types.- $cmphas this syntax:- { $cmp: [ <expression1>, <expression2> ] } - For more information on expressions, see Expression Operators. 
Example
Create an inventory collection with these documents:
db.inventory.insertMany( [    { _id : 1, item : "abc1", description: "product 1", qty: 300 },    { _id : 2, item : "abc2", description: "product 2", qty: 200 },    { _id : 3, item : "xyz1", description: "product 3", qty: 250 },    { _id : 4, item : "VWZ1", description: "product 4", qty: 300 },    { _id : 5, item : "VWZ2", description: "product 5", qty: 180 } ] ) 
Use the $cmp operator to compare the qty value with 250:
db.inventory.aggregate(    [      {        $project:           {             item: 1,             qty: 1,             cmpTo250: { $cmp: [ "$qty", 250 ] },             _id: 0           }      }    ] ) 
Output:
{ item : "abc1", qty : 300, cmpTo250 : 1 } { item : "abc2", qty : 200, cmpTo250 : -1 } { item : "xyz1", qty : 250, cmpTo250 : 0 } { item : "VWZ1", qty : 300, cmpTo250 : 1 } { item : "VWZ2", qty : 180, cmpTo250 : -1 }