3

好的,这就是我遇到的问题。我有一个模型,它在直通表中的条件下设置了两个关系。

has_one :link_resource, through: :resource_contexts, source: :resource, conditions: ['resource_contexts.question_id = ? ', -1]
has_many :sample_plans, through: :resource_contexts, source: :resource, conditions: ['resource_contexts.question_id = ? ', -2]

然后,在我的控制器中,我尝试使用

@funder_templates = FunderTemplate.find(:all, include: [:sample_plans, :link_resource], conditions: {active: true})

但是由于某种原因,sql 是这样出来的

ResourceContext Load (0.2ms)  SELECT `resource_contexts`.* FROM `resource_contexts` WHERE (`resource_contexts`.funder_template_id IN (2,3,4,5,6,7,8,9,10,11,12,13,14,20,21,22,23,24,25,26,27,30,40) AND (resource_contexts.question_id = -2 ))

请注意,它只查找第一个关系的条件,而不是第二个关系。我不知道我正在做的事情是否太复杂以至于 ActiveRecord 无法处理,或者我只是写错了。任何帮助,将不胜感激。

导轨 3.0.20

红宝石 1.9.2

编辑:澄清一下,真正搞砸的部分是@funder_templates.sample_plans 是正确的,但@funder_templates.link_resource 也是示例计划!没有包含,关系工作正常,只是没有优化。

4

1 回答 1

0

Did you try ? @funder_templates = FunderTemplate.where(active: true).includes([:sample_plans, :link_resource])

I think, it should work

于 2013-05-02T23:01:18.090 回答