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)
难道我做错了什么?
您面临的问题是由 Mongoid gem 引起的。升级到最新版本的 Mongoid gem 将解决该问题。
有关该错误的更多信息可以在此处找到
https://github.com/mongoid/origin/pull/83