Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ruby-on-rails/66.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ruby-on-rails-3/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails 子属性上的ActiveRelation where语句_Ruby On Rails_Ruby On Rails 3_Activerecord - Fatal编程技术网

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的语法和解释方面提供的帮助!