jjzjj

MongoDB:$divide 和 $multiply 出错

coder 2023-05-04 原文

我正在创建一个 MongoDB 聚合管道,但我被困在这个阶段:

        $group: {
            _id: {checkType: "$_id.checkType", resultCode: "$_id.resultCode"},
            count: { $sum: "$count" },
            ctv: { $sum: "$ctv" },
            perc:{$multiply:[{$divide:["$ctv","$count"]},100]},
            weight: { $divide: [ "$ctv", "$count"] },
            details: { $push: "$$ROOT" }
        }

它给出错误“$multiply 累加器是一元运算符”。同样,如果我用 $multiply 删除该行,我会在下一行得到“$divide 累加器是一元运算符”。我在网上找不到这个错误的描述。我的语法有什么问题?

最佳答案

arithmetic operators不能用作 $group accumulators .将它们移至另一个 $project 流水线阶段为:

db.collection.aggregate([
    { "$group": {
        "_id": { "checkType": "$_id.checkType", "resultCode": "$_id.resultCode" },
        "count": { "$sum": "$count" },
        "ctv": { "$sum": "$ctv" },
        "details": { "$push": "$$ROOT" }
    } },
    { "$project": {
        "count": 1,
        "details": 1,
        "ctv": 1,
        "perc": { "$multiply": [ { "$divide": ["$ctv","$count"] }, 100 ] },
        "weight": { "$divide": ["$ctv", "$count"] },
    } }
])

如果使用 MongoDB 3.4 及更高版本,请使用 $addFields 而不是 $project

db.collection.aggregate([
    { "$group": {
        "_id": { "checkType": "$_id.checkType", "resultCode": "$_id.resultCode" },
        "count": { "$sum": "$count" },
        "ctv": { "$sum": "$ctv" },
        "details": { "$push": "$$ROOT" }
    } },
    { "$addFields": {
        "perc": { "$multiply": [ { "$divide": ["$ctv","$count"] }, 100 ] },
        "weight": { "$divide": ["$ctv", "$count"] },
    } }
])

关于MongoDB:$divide 和 $multiply 出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43341863/

有关MongoDB:$divide 和 $multiply 出错的更多相关文章

  1. ruby-on-rails - 无法在centos上安装therubyracer(V8和GCC出错) - 2

    我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e

  2. ruby - 安装libv8(3.11.8.13)出错,Bundler无法继续 - 2

    运行bundleinstall后出现此错误:Gem::Package::FormatError:nometadatafoundin/Users/jeanosorio/.rvm/gems/ruby-1.9.3-p286/cache/libv8-3.11.8.13-x86_64-darwin-12.gemAnerroroccurredwhileinstallinglibv8(3.11.8.13),andBundlercannotcontinue.Makesurethat`geminstalllibv8-v'3.11.8.13'`succeedsbeforebundling.我试试gemin

  3. ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB - 2

    我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

  4. ruby - 使用 mongodb/mongoid 运行时更改模型 - 2

    我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

  5. ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb? - 2

    我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")

  6. ruby - MongoDB:无法从 BSON 类型 EOO 转换为 Date - 2

    我正在尝试使用聚合框架(使用ruby​​)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u

  7. ruby - 在 Ruby 中从 MongoDB 中检索字段的子集 - 2

    我试图通过在Ruby中进行的查询从MongoDB获取字段的子集,但它似乎不起作用。它不返回任何结果这是ruby代码:coll.find("title"=>'Halo',:fields=>["title","isrc"])#thisdoesn'twork如果我删除字段散列,它会工作,返回包含所有字段的结果coll.find("title"=>'Halo')#thisworks查看mongodb控制台,第一个查询在mongodb服务器上结束,如下所示:{title:"Halo",fields:["title","isrc"]}如果我尝试从mongo客户端控制台进行查询,它会工作,我会得到结

  8. ruby - celluloid gem 安装出错 - 2

    最近我将我的Rails版本更新到4.2.3并将ruby​​版本更新到ruby-2.2.3。之后,当我bundle它时会出现以下错误:$bundleFetchinggemmetadatafromhttp://rubygems.org/..........Fetchingversionmetadatafromhttp://rubygems.org/...Fetchingdependencymetadatafromhttp://rubygems.org/..Couldnotfindcelluloid-0.16.1inanyofthesources你能帮帮我吗? 最

  9. ruby-on-rails - Ruby on Rails - 捆绑安装期间出错 - 2

    我一直在谷歌下面搜索这个错误,但我无法解决这个错误:Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./usr/bin/ruby2.1extconf.rbmkmf.rbcan'tfindheaderfilesforrubyat/usr/lib/ruby/include/ruby.hextconffailed,exitcode1Gemfileswillremaininstalledin/home/dyego/.bundler/tmp/9200/gems/sqlite3-1.3.9forinspection.Results

  10. ruby-on-rails - "Expected string default value for ` --jbuilder `; got true (boolean)"新建rails项目出错 - 2

    我正在开始一个新项目,现在已经做了很多次了。但是,这是我第一次遇到这个问题!我正常创建应用railsnewmyapp-dpostgresql我使用railsdb:create创建了数据库并运行了站点railss。一切正常,我看到了Rails欢迎/等待页面。现在我开始创建我的模型,例如railsgmodeluser。我明白了!Expectedstringdefaultvaluefor`--jbuilder`;gottrue(boolean)invokeactive_recordThename'User'iseitheralreadyusedinyourapplicationorreser

随机推荐