我有以下 3 个 rails 类,它们都存储在一个表中,使用 rails 的单表继承。
class Template < ActiveRecord::Base
class ThingTemplate < Template
class StockThingTemplate < ThingTemplate
如果我有一个StockThingTemplate
ID ,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'
在不同的地方尝试过。它要么没有效果,要么导致其他问题