Ruby on rails 子属性上的ActiveRelation where语句
我有一个条件,我正试图访问,但有一点麻烦Ruby on rails 子属性上的ActiveRelation where语句,ruby-on-rails,ruby-on-rails-3,activerecord,Ruby On Rails,Ruby On Rails 3,Activerecord,我有一个条件,我正试图访问,但有一点麻烦 Solicitation belongs_to :lead Lead has_many :solicitations 我的第一条语句获取用户的所有请求 @solicitations = current_user.solicitations.includes(:lead) 我已经可以访问属性lead.case_类型,并且可以在关系中循环并手动将它们放置在它们的位置,但我认为它们是一种更简单的方法 我想做的是类似于 @solicitations.wher
Solicitation belongs_to :lead
Lead has_many :solicitations
我的第一条语句获取用户的所有请求
@solicitations = current_user.solicitations.includes(:lead)
我已经可以访问属性lead.case_类型,并且可以在关系中循环并手动将它们放置在它们的位置,但我认为它们是一种更简单的方法
我想做的是类似于
@solicitations.where("lead.case_type = ?", "Civil")
我尝试了这些,但收到未知列错误lead.case\u type
Solicitation.all(:conditions => {:lead => {:case_type => 'Civil'}}, :joins => :lead)
问题是您使用的是
lead.case\u type
,但是(如果您遵循Rails的约定),您的表名是leads
。这应该起作用:
@solicitations = current_user.solicitations.includes(:lead).where("leads.case_type = ?", "Civil")
您还可以使用:
@solicitations = current_user.solicitations.joins(:lead).where("leads.case_type = ?", "Civil")
includes
执行外部联接,而联接
执行内部联接。因为您正在查询联接表,所以这里最好使用内部联接
在
中,其中
必须始终使用表名(复数),但在中,包括
和连接
则取决于关系。在这种情况下,请求
属于潜在客户
,因此您必须使用:潜在客户
(单数)。这有点让人困惑,但我希望这能为您澄清。问题是您使用的是lead.case\u type
,但是(如果您遵循Rails的惯例),您的表名是leads
。这应该起作用:
@solicitations = current_user.solicitations.includes(:lead).where("leads.case_type = ?", "Civil")
您还可以使用:
@solicitations = current_user.solicitations.joins(:lead).where("leads.case_type = ?", "Civil")
includes
执行外部联接,而联接
执行内部联接。因为您正在查询联接表,所以这里最好使用内部联接
在
中,其中
必须始终使用表名(复数),但在中,包括
和连接
则取决于关系。在这种情况下,请求
属于潜在客户
,因此您必须使用:潜在客户
(单数)。这有点让人困惑,但我希望这能为您澄清。这两种方法都有效,非常感谢您在join vs.include的语法和解释方面提供的帮助!这两种方法都很有效,非常感谢您在join vs.include的语法和解释方面提供的帮助!