草庐IT

add_group

全部标签

mongodb - Mongo 聚合 : add conditional fields

我有一个包含多个阶段的聚合管道。在这些阶段之后,简化的结果是这样的:{feature1:[{random:125}],feature2:[{a:"fsfs",val:[125]}]}我想添加一个新字段type,它是根据这些条件设置的:feature1.size>0和feature2.size>0然后输入='back'feature2.size>0然后输入='front'否则类型='none'feature1和feature2数组的内容并不重要,类型取决于数组是否被填充。我的想法是使用带有$cond运算符的$addFields阶段,但我无法弄清楚语法。 最佳答

javascript - 获取 $group by 之后的最新文档

我正在使用officialMongoDBdriver对于Node.js。这就是我的消息数据的结构。如您所见,每个帖子都有一个时间戳、一个用户ID和主题ID。[{"_id":ObjectId("5b0abb48b20c1b4b92365145"),"topicId":"XN7iqmCFD4jpgJZ6f","timestamp":1527429960,"user":"5b0869636f4e363e300d105a","content":"loremipsum"}]现在我需要检查是否有主题,最新的帖子(=最高时间戳)与我自己的ID不匹配。这样我就知道哪个主题有新答案(这不是我自己的帖子)

mongodb - 如何在 MongoDB 中自定义 $group 输出?

应用$group阶段后,我得到以下结果:[{_id:{month:7,day:19,year:2018},count:4}]是否可以应用另一个阶段并获得如下输出:[{date:'7-19-2018',count:4}] 最佳答案 您可以使用$dateFromParts将日期部分转换为日期,后跟$dateToString在3.6中将其转换为字符串。有点像{"$project":{"_id":0,"date":{"$dateToString":{"format":"%m-%d-%Y","date":{"$dateFromParts":{

mongodb - 使用 mongodb 的多级 $group

我正在尝试获取MongoDB中某个键的所有不同值的计数。我也得到了计数,但我得到了2个不同的对象。{"_id":ObjectId("596f6e95b6a1aa8d363befeb"),produce:"potato","variety":"abc","state":'PA'}{"_id":ObjectId("596f6e95b6a1aa8d363befec"),produce:"potato","variety":"abc","state":'PA'}{"_id":ObjectId("596f6e95b6a1aa8d363befed"),produce:"potato","varie

MongoDB 聚合到 $group 和 conditionally $addToSet

给定以下虚拟集合,我想提取给定资源的导出国和进口国:[{country:"France",exchange:{export:[{resource:"MILK",origin:["Toulouse","Bordeaux"]}],import:[{resource:"BEEF",origin:["Lyon","Marseille"]}]}},{country:"Spain",exchange:{export:[{resource:"PORK",origin:["Madrid","Barcelona"]}],import:[{resource:"MILK",origin:["Valencia

mongodb - 在 ansible playbook for mongodb 中出现 rs.add() 问题

我在我的剧本中使用以下任务来初始化集群并将辅助节点添加到主要节点:-name:Initializereplicasetrun_once:truedelegate_to:host1shell:>mongo--eval'printjson(rs.initiate())'-name:Formatsecondariesrun_once:truelocal_action:module:debugmsg:'"{{item}}:27017"'with_items:['host2','host3']register:secondaries-name:Addsecondariesrun_once:tru

java - MongoDB group() 函数中的 Long 累加器而不是 Double

我正在通过官方JavaAPI使用MongoDB。我可以毫不费力地存储和检索Long值。但是,当我尝试使用group()函数累积这些值时,JavaScript解释器将所有内容都转换为Double,最终结果为Double。这是我的组命令:{...initial:{count:0},reduce:"function(o,a){a.count+=o.count;}"}有没有办法告诉解释器count实际上是一个Long?像count:0L或count:Long(0)这样的东西?还是应该做Java端的积累? 最佳答案 这是因为group命令实际

ruby-on-rails - 如何使用 mongoid 将 add_to_set 添加到多个数组并在单个查询中进行触摸

我希望添加到多个集合,同时更新updated_at时间戳(触摸)。我可以使用mongo驱动程序做到这一点:db.mycollection.update({"_id":ObjectId("911")},{$addToSet:{"hashtags":{$each:["#test1","#test5"]},"new_hash":{$each:["test9"]}},$set:{"updated":"currenttime3"}})我如何在Rails应用程序中使用mongoid在单个更新查询中执行此操作。现在,我需要使用mongoid进行3次写入:my_object.add_to_set("h

javascript - MongoDB Group By _id 的时间戳

我希望按创建日期对一堆文档进行分组。使用MongoDB聚合框架,是否可以按_id的时间戳对文档进行分组?类似的东西db.sessions.aggregate({$group:{_id:{$dayOfYear:"$_id.getTimestamp()"},count:{$sum:1}}})谢谢 最佳答案 您在这里提到的函数是作为ObjectId包装器的shell帮助程序实现的JavaScript方法。各种语言的其他驱动程序实现包含类似的方法,其基本功能可以从mongoshell中看到,如下所示:function(){returnnew

mongodb - Mongo 副本集 `rs.add()` 使初始主要次要并呈现主要 `fatal`

我这辈子都做不到,我无法获得>1个成员的副本设置。我开始了一个似乎正确的主要任务:sb-rs:PRIMARY>rs.status(){"set":"sb-rs","date":ISODate("2014-09-16T22:38:53Z"),"myState":1,"members":[{"_id":0,"name":"primary-hostname:27017","health":1,"state":1,"stateStr":"PRIMARY","uptime":1213,"optime":Timestamp(1410904778,2),"optimeDate":ISODate("2