3

我有以下 3 个 rails 类,它们都存储在一个表中,使用 rails 的单表继承。

class Template < ActiveRecord::Base
class ThingTemplate < Template
class StockThingTemplate < ThingTemplate

如果我有一个StockThingTemplateID ,150那么我在逻辑上应该能够做到这一点:

ThingTemplate.find(150)
=> #returns me the StockThingTemplate

事实上,这有时是有效的

当它工作时,它会生成以下 SQL 查询:

SELECT * FROM templates WHERE (templates.`id` = 159) AND ( (templates.`type` = 'ThingTemplate') OR (templates.`type` = 'StockThingTemplate' ) )

当它不起作用时,它会生成以下 SQL 查询:

SELECT * FROM templates WHERE (templates.`id` = 159) AND ( (templates.`type` = 'ThingTemplate') )

sql 正在做它应该做的事情,但问题是,为什么它一次生成一组 SQL,而另一次生成另一组不同的 SQL。它实际上是完全相同的代码。

笔记:

  • 我在轨道上 1.2
  • 我已经require 'stock_thing_template'在不同的地方尝试过。它要么没有效果,要么导致其他问题
4

1 回答 1

7

好的。原来这是因为 rails 并不总是看到整个继承层次结构。由于它在每个请求上重新加载所有项目,这解释了不一致的行为(在某些地方,before_filter 可能导致模型加载,在其他地方可能不会)。

它可以通过放置来固定

require_dependency 'stock_thing_template'

在我所有引用这些东西的控制器的顶部。

有关 rails wiki 的更多信息- 转到页面底部

于 2008-10-21T02:53:08.690 回答