Skip to main content

How to get absolute value in MongoDB

To get the absolute value we can use $abs operator. $abs is the arithmetic aggregate operator which returns the absolute value of the number.
Absolute value means it always returns positive value while the number may positive or negative.

Before version of MongoDB 3.2, we can’t use directly on the number like below.

{ $project: { number: { $abs: '$number } }  

We needed some calculation as below.

     $project: { abs_value: { $abs: { $subtract: [ 1, 2 ] } } }

{ $abs: <number> }

Example: Run the following script which $subtract will return negative value but $abs will return the absolute value of subtract.

     $project: { abs_value: { $abs: { $subtract: [ 1, 2 ] } } }


     $project: { abs_value: { $abs: -1 } }

It will return abs_value =1.0

Note: If the argument field is missing or null it will return null.

{$abs:-1} result 1
{$abs:1} result 1

{$abs:null} result null

Popular posts from this blog

Add day to ISODate in MongoDB

We can use $add operator to add days in ISODate in mongodb, $add is the Arithmetic Aggregation Operator which adds number and date in mongodb.

{ $add: [ <expression1>, <expression2>, ... ] }

Note:  If one of the argument is date $add operator treats to other arguments as milliseconds to add to the date.
Example: Suppose we have a Test collection as below.

{"Title" : "Add day to ISODate in MongoBD","CreatedDate" : ISODate("2016-07-07T08:00:00.000Z")}

Query to add 2 days in CreatedDate

db.Test.aggregate([      { $project: { Title: 1, AddedDate: { $add: [ "$CreatedDate", 2*24*60*60000 ] } } }    ])


{ "_id" : ObjectId("579a1567ac1b3f3732483de0"), "Title" : "Add day to ISODate in MongoBD", "AddedDate" : ISODate("2016-07-09T08:00:00.000Z") }

Note: As mentioned in above note we have to convert days in millisecond because $add operator treat to other arg…

Remove special character from string in MongoDB

Problem: Suppose wehave a collection and one field is type string contains some special character (like !@#$%) and we don’t want these special character.
Solution: We can easily remove the special character from field using script “replace(/[^a-zA-Z 0-9 ]/g, '')” in our query.  How can we remove special character from string using this script please see following example.
Example: Suppose we have a collection “EduSurvey “where we are collecting information from institutions.

{Name:"JB institute”, About:"This is good one collage for MBA", Information:"This $%%institute ##has good faculty etc$$"}
{Name:"MK institute”, About:"This is good one collage for MCA", Information:"This$$%# is the dummy text12"}
{Name:"MG institute”, About:"This is good one collage for B,Tech", Information:"This# institute@ has&* good infrastructure"}

Did you notice Information fields contains some special character so we…