繁体   English   中英

Rails 3 ActiveRecord查询数组中

[英]Rails 3 ActiveRecord query in an array

我有一个模型与另一个模型具有one_to_many关系:

user.area_ids = [1, 2, 3]

然后是另一种共享关系但一对一的模型。

listing.area_id = 1

如何查询所有Area_id为1 2或3的列表。我希望做类似的事情...

Listing.where("area_id IN ?", user.area_ids) 

但这是行不通的。

任何帮助,将不胜感激!

你太聪明了 Rails知道如何做where(field: [1,2,3])就好了。

如果您where提供常规key: value ,其中value是一个数组,它将为您建立where FIELD in (a,b,c)where FIELD in (a,b,c)

只需使用

Listing.where(area_id: user.area_ids)  # select ... where area_id in (1,2,3)

您忘记了问号附近的括号:)尝试以下操作:

Listing.where("area_id IN (?)", user.area_ids) 

但是对我来说,更正确的方法是借助

class User 
  has_many :areas
  has_many :listings, through: :areas
end

然后打电话

user.listings

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM