我有一个类层次结构,如下所示:
class Post < ActiveRecord::Base; end class Project < Post; end class ProjectDesignWall < Project; end
有一个控制器可以像这样获取数据:
@projects = Project.find(:all, :include => [:project_image_photos,:user])
在development
,这将直接从日志运行以下查询:
SELECT * FROM `posts` WHERE ( (`posts`.`type` = 'Project' ) ) ORDER BY originally_created_at DESC
但是,只要它在production
模式下运行,即使使用相同的数据库和数据,也会产生以下查询:
SELECT * FROM `posts` WHERE ( (`posts`.`type` = 'Project' OR `posts`.`type` = 'ProjectDesignWall' ) ) ORDER BY originally_created_at DESC
有谁知道为什么会这样,有没有办法让它至少表现得一致,如果没有完全解决问题?
因为在生产中,所有类都会立即加载.当所有类都加载时,它意识到ProjectDesignWall是Project的子类,因此收集了所有类.