sql >> Database >  >> NoSQL >> MongoDB

Afronding op 2 decimalen met behulp van het MongoDB-aggregatieraamwerk

Er is geen $round operator, maar u kunt dit doen in het aggregatieraamwerk - als u dit in een specifieke volgorde doet, vermijdt u meestal problemen met de precisie van drijvende komma's.

> db.a.save({x:1.23456789})
> db.a.save({x:9.87654321})
> db.a.aggregate([{$project:{ _id:0, 
         y:{$divide:[
              {$subtract:[
                      {$multiply:['$x',100]},
                      {$mod:[{$multiply:['$x',100]}, 1]}
              ]},
              100]}
}}])
{ "y" : 1.23 }
{ "y" : 9.87 }

Gezien de bestaande pijplijn in het probleem, vervangt u:

{$multiply:[{$divide: ['$ActSls', '$PlnSls']},100]}

met

{$divide:[
     {$subtract:[ 
          {$multiply:[
             {$divide: ['$ActSls','$PlnSls']},
             10000
          ]}, 
          {$mod:[
             {$multiply:[{$divide: ['$ActSls','$PlnSls']}, 10000 ]},
             1]}
          ]}, 
     100
]}

Met uw voorbeeldgegevenspunten is dit het resultaat:

{ "ActSls" : 31, "PlnSls" : 51, "ActToPln" : 60.78 }
{ "ActSls" : 41, "PlnSls" : 51, "ActToPln" : 80.39 }
{ "ActSls" : 72, "PlnSls" : 102, "ActToPln" : 70.58 }


  1. Benchmark Apache HBase vs Apache Cassandra op SSD in een cloudomgeving

  2. Is er een manier om een ​​specifieke sleutel te lokaliseren op een specifieke redis-instantie in clustermodus?

  3. Mongoose Probeert een niet-gesloten verbinding te openen

  4. Uw gegevens beveiligen met ClusterControl