首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails 3 ActiveRecord:通过查找关联来查找模型

Rails 3 ActiveRecord:通过查找关联来查找模型
EN

Stack Overflow用户
提问于 2011-05-03 20:11:58
回答 1查看 789关注 0票数 6
代码语言:javascript
复制
class OrderItem belongs_to Item and belongs_to Order

class Item has_many OrderItems and belongs_to ItemType

class ItemType has_many Items

class Order has_many OrderItems

我想在订单中查找其项目类型为ItemType的所有OrderItems

代码语言:javascript
复制
def get_by_item_type(id)
  order_items.where(:item => {:item_type_id => 3})

显然,我可以通过查找所有OrderItems、循环、测试和构建自己的集合来做到这一点。没问题,但我想知道有没有别的办法?

谢谢/j

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-03 21:03:42

这可以通过以下方式完成:

代码语言:javascript
复制
def get_by_item_type(id)
  order_items.joins(:item).where(:item_type_id => id)
end

如果您收到关于不存在/不明确列的错误,请查看

代码语言:javascript
复制
order_items.joins(:items).to_sql

以便找到正确的列名。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5869252

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档