Единственное наследование таблицы находит проблемы - PullRequest
3 голосов
/ 21 октября 2008

У меня есть следующие 3 класса rails, которые все хранятся в одной таблице с использованием наследования Single table для rails.

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

Если у меня есть StockThingTemplate с идентификатором 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 один раз, а другой - другой. Это буквально тот же самый код.

Примечания:

  • Я на рельсах 1.2
  • Я уже пробовал require 'stock_thing_template' в разных местах. Это либо не имеет никакого эффекта, либо вызывает другие проблемы

1 Ответ

7 голосов
/ 21 октября 2008

OK. Оказывается, это потому, что rails не видит всю иерархию наследования все время. Поскольку он перезагружает все элементы при каждом запросе, это объясняет противоречивое поведение (в некоторых местах before_filter, вероятно, вызывал загрузку моделей, в других местах, возможно, нет).

Это можно исправить, поставив

require_dependency 'stock_thing_template'

на вершине всех моих контроллеров, которые ссылаются на эти вещи.

Более подробная информация о рельсах wiki - перейти в конец страницы

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...