Mongoid `group()` 条件

2024-01-04

我想为 Mongoid 中的分组提供一个条件,但是如何为条件哈希中的属性发送多个值?这就是我想做的:

PageViews.collection.group(
  cond: {page_id: ['4e6912618083ab383e000010', '4e6912618083ab383e000009']},
  key: 'timestamp',
  initial: {count: 0},
  reduce: "function(x, y) {y.count += x.count;}"
)

因此任何PageView与任一page_id将成为查询的一部分,但我似乎无法获得条件哈希(cond)根本不去工作!我在这里做错了什么,我真的很困惑。

这是 API 文档group()方法:http://api.mongodb.org/ruby/current/Mongo/Collection.html#group-instance_method http://api.mongodb.org/ruby/current/Mongo/Collection.html#group-instance_method

任何帮助将不胜感激。


update

像这样运行查询:

PageViews.collection.group(
  cond: {page_id: { $in : ['4e6912618083ab383e000010', '4e6912618083ab383e000009']}},
  key: 'timestamp',
  initial: {count: 0},
  reduce: "function(x, y) {y.count += x.count;}"
)

返回以下错误,但语法对我来说看起来很好:

SyntaxError: (irb):170: syntax error, unexpected ':', expecting tASSOC
  cond: {page_id: { $in : ['4e6912618083ab383e000010',...
                         ^
(irb):170: syntax error, unexpected '}', expecting $end
...', '4e6912618083ab383e000009']}},
...                               ^
    from /usr/local/lib/ruby/gems/1.9.1/gems/railties-3.1.0/lib/rails/commands/console.rb:45:in `start'
    from /usr/local/lib/ruby/gems/1.9.1/gems/railties-3.1.0/lib/rails/commands/console.rb:8:in `start'
    from /usr/local/lib/ruby/gems/1.9.1/gems/railties-3.1.0/lib/rails/commands.rb:40:in `<top (required)>'
    from script/rails:6:in `require'
    from script/rails:6:in `<main>'

令人沮丧的是,在任何地方都没有这样的例子,文档说条件参数是这样的:

(String, BSON::Code) :cond — 默认值:{} — 指定一个文档 用于过滤运行聚合的文档的查询 (选修的)。

所以如果需要一个String or BSON::Code,这会是什么样子?


你需要使用$in使查询与多个值匹配。所以它会写成

PageViews.collection.group(
  :cond => {:page_id => { '$in' => ['4e6912618083ab383e000010', '4e6912618083ab383e000009']}},
  :key => 'timestamp',
  :initial => {count: 0},
  :reduce => "function(x, y) {y.count += x.count;}"
)    

你可以在这里读更多关于它的内容:http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24in http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24in

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Mongoid `group()` 条件 的相关文章

随机推荐