我是 Mongo 的新手,我有以下任务:
运行 Mongo 3.4.2。
收藏:
[
{
"docID": "aaa111",
"version": 1,
"somefield1": "abc"
},
{
"docID": "aaa111",
"version": 2,
"somefield1": "abc",
"somefield2": "abc"
},
{
"docID": "bbb222",
"version": 1,
"somefield1": "abc",
"somefield2": "abc"
},
{
"docID": "bbb222",
"version": 2,
"somefield1": "abc",
"somefield3": "abc"
},
{
"docID": "bbb222",
"version": 3,
"somefield2": "abc",
"somefield3": "abc"
}
]
换句话说,具有相同 docID 的文档可能具有不同的“架构”。
我需要查询此集合返回的是具有最新版本的文档,以及那些特定文档的所有字段。
下面是基于上述集合的查询输出应该是这样的:
[
{
"docID": "aaa111",
"version": 2,
"somefield1": "abc",
"somefield2": "abc"
},
{
"docID": "bbb222",
"version": 3,
"somefield2": "abc",
"somefield3": "abc"
}
]
我一直在尝试按如下方式使用 $aggregate 运算符:
db.collection.aggregate(
[
{ $sort: { docID: 1, version: 1 } },
{ $group:
{
_id: "$docID",
latestVersion: { $last: "$version" }
}
}
]
)
但这只返回 2 个字段,docID 和最新版本。
然后我尝试使用 $in 运算符使用 find() 从该集合中进行选择,其中 $in 将接受上述查询,但是,一个问题是 $in 期望和数组,其次,我需要选择docID 和版本与子查询结果匹配的文档。
如何获取具有docID和最新版本的文档的所有字段?
感谢任何帮助。
提前致谢。
最佳答案
使用 $$ROOT 和 $last 累加器来获取所有根文档字段
db.collection.aggregate([
{ "$sort": { "docID": 1, "version": 1 }},
{ "$group": {
"_id": "$docID",
"last": { "$last": "$$ROOT" }
}},
{ "$replaceRoot": { "newRoot": "$last" }}
])
关于MongoDB - 查询集合以返回所有最新版本的文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54892346/
我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
当我的预订模型通过rake任务在状态机上转换时,我试图找出如何跳过对ActiveRecord对象的特定实例的验证。我想在reservation.close时跳过所有验证!叫做。希望调用reservation.close!(:validate=>false)之类的东西。仅供引用,我们正在使用https://github.com/pluginaweek/state_machine用于状态机。这是我的预订模型的示例。classReservation["requested","negotiating","approved"])}state_machine:initial=>'requested
我有这个html标记:我想得到这个:我如何使用Nokogiri做到这一点? 最佳答案 require'nokogiri'doc=Nokogiri::HTML('')您可以通过xpath删除所有属性:doc.xpath('//@*').remove或者,如果您需要做一些更复杂的事情,有时使用以下方法遍历所有元素会更容易:doc.traversedo|node|node.keys.eachdo|attribute|node.deleteattributeendend 关于ruby-Nokog
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c