在此先感谢您的帮助!所以,我有两个集合:A 和 B。
A 是个人信息的集合:
{
"_id": "3453hkj54h5k34j5hkjh"
"location": "New York, U.S.",
"first-name": "Archer",
"last-name": "Vice",
"industry": "intelligence"
},
{
"_id": "3453hkj5sdfdddjh",
"location": "London, UK",
"first-name": "Harry",
"last-name": "Potter",
"industry": "security"
},
{
"_id": "345dfdf5sdfdddjh",
"location": "D.C., US",
"first-name": "Obama",
"last-name": "Barack",
"industry": "president"
}
B是美国位置信息的集合:
{
"_id": "998sdfdsfhejf",
"city": "New York",
"zip": "10122",
"state": "NY",
"lat": 40.749,
"longt": -73.9885
},
{
"_id": "998sdfsdfdsfhejf",
"city": "D.C."
"zip": "20500",
"state": "DC",
"lat": 38.8951,
"longt": -77.0369
}
我要通过比较 A 中的位置字段与 B 中的城市字段来找出谁住在美国。B 应该是 A 的子字符串,因为 A 经常携带州或国家/地区信息。
我已经通过以下方式将 B 转换为数组:
var f = db.collection.find(), n = [];
for (var i = 0; i < f.length(); i++) n.push(f[i]['field']);
现在 B 是 var n=["D.C.", "New York"]
我知道如何检查数组中是否有内容。你这样做:
db.database.find({
field:
{
$in: array
}
});
要检查子字符串,您可以这样做:
db.database.find({A: /substring/ });
或
db.database.find({A: {$regex: 'substring'}});
预期结果是
{
"_id": "3453hkj54h5k34j5hkjh",
"location": "New York, U.S.",
"first-name": "Archer",
"last-name": "Vice",
"industry": "intelligence"
},
{
"_id": "345dfdf5sdfdddjh",
"location": "D.C., US",
"first-name": "Obama",
"last-name": "Barack",
"industry": "President"
}
"D.C., US" 包含子字符串 "D.C.",它是数组 n=["D.C.", "New York"]。
我知道我可以通过 mapreduce 来做到这一点,但它看起来真的只是一行。我也在学习如何加入这两个集合。
最佳答案
这在声明中不是 super 简单,但它是可能的。如果您的搜索词列表与您在问题中所述的一样短,您可以在一行中将其组合成一个正则表达式,如下所示:
db.test.find({location: {$regex: new RegExp(n.join('|'))}})
如果列表不是太长。如果正则表达式太复杂,它会很慢。如果它很短,你可以当然,那么你也可以按字面意义写出 RegExp。
n 是在 shell 中定义的,就像您在问题中所定义的那样。我在这里使用:
var n = ["D.C.", "New York"];
这将给出以下结果:
{ "_id" : "3453hkj54h5k34j5hkjh", "location" : "New York, U.S.", "first-name" : "Archer", "last-name" : "Vice", "industry" : "intelligence" }
{ "_id" : "345dfdf5sdfdddjh", "location" : "D.C., US", "first-name" : "Obama", "last-name" : "Barack", "industry" : "president" }
如果您的列表太长,这里是您加入的替代方法:
n.reduce(function (lst, d) {
var res = db.test.find({location: {$regex: d}}).toArray();
Array.prototype.push.apply(lst, res);
return lst;
}, []);
它遍历列表中的所有条目并找到匹配的条目并将所有结果添加到一个新列表中。
如果你愿意,你可以将它们插入到一个新的集合中,而不是将它们全部保存在内存中。您也可以直接使用搜索,而不是将集合 B 中的结果提取到列表中。这在内存方面应该也更好。
这会将结果保存到名为 test_result 的集合中(在搜索中使用集合 A 和 B):
db.B.find().forEach(function (d) {
db.test_result.insert(db.A.find({location: {$regex: d.city}}).toArray())
});
关于arrays - Mongodb 根据字段是否包含数组值作为子字符串来查询集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29775603/
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我怎样才能完成http://php.net/manual/en/function.call-user-func-array.php在ruby中?所以我可以这样做:classAppdeffoo(a,b)putsa+benddefbarargs=[1,2]App.send(:foo,args)#doesn'tworkApp.send(:foo,args[0],args[1])#doeswork,butdoesnotscaleendend 最佳答案 尝试分解数组App.send(:foo,*args)
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby数组,我们在StackOverflow上找到一
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
通过rubykoans.com,我在about_array_assignment.rb中遇到了这两段代码你怎么知道第一个是非并行赋值,第二个是一个变量的并行赋值?在我看来,除了命名差异之外,代码几乎完全相同。4deftest_non_parallel_assignment5names=["John","Smith"]6assert_equal["John","Smith"],names7end45deftest_parallel_assignment_with_one_variable46first_name,=["John","Smith"]47assert_equal'John