相交的Mongoid"in"-Queries

Phi*_*hil 9 ruby-on-rails mongodb mongoid

根据显式合并的mongoid文档(" 可查询#in - 默认为交叉"),我希望以下查询:

Contact.in(id: ['a', 'b']).in(id: ['b', 'c'])
Run Code Online (Sandbox Code Playgroud)

导致这样的事情:

=> #<Mongoid::Criteria
  selector: {"_id"=>{"$in"=>["b"]}}
  options:  {}
  class:    Contact
  embedded: false>
Run Code Online (Sandbox Code Playgroud)

但相反,我得到了所有可以想象的情况的覆盖:

[1] pry(main)> Contact.in(id: ['a', 'b']).in(id: ['b', 'c'])
=> #<Mongoid::Criteria
  selector: {"_id"=>{"$in"=>["b", "c"]}}
  options:  {}
  class:    Contact
  embedded: false>

[2] pry(main)> Contact.in(id: ['a', 'b']).intersect.in(id: ['b', 'c'])
=> #<Mongoid::Criteria
  selector: {"_id"=>{"$in"=>["b", "c"]}}
  options:  {}
  class:    Contact
  embedded: false>

[3] pry(main)> Contact.in(id: ['a', 'b']).union.in(id: ['b', 'c'])
=> #<Mongoid::Criteria
  selector: {"_id"=>{"$in"=>["b", "c"]}}
  options:  {}
  class:    Contact
  embedded: false>
Run Code Online (Sandbox Code Playgroud)

难道我做错了什么?

Vis*_*d R 1

您面临的问题是由 Mongoid gem 引起的。升级到最新版本的 Mongoid gem 将解决该问题。

有关该错误的更多信息可以在此处找到

https://github.com/mongoid/origin/pull/83