ActiveRecord在生产中运行不同的查询?

Luk*_*uke 3 ruby environment activerecord ruby-on-rails

我有一个类层次结构,如下所示:

class Post < ActiveRecord::Base; end
class Project < Post; end
class ProjectDesignWall < Project; end
Run Code Online (Sandbox Code Playgroud)

有一个控制器可以像这样获取数据:

@projects = Project.find(:all, :include => [:project_image_photos,:user])
Run Code Online (Sandbox Code Playgroud)

development,这将直接从日志运行以下查询:

SELECT * FROM `posts` WHERE ( (`posts`.`type` = 'Project' ) ) ORDER BY originally_created_at DESC
Run Code Online (Sandbox Code Playgroud)

但是,只要它在production模式下运行,即使使用相同的数据库和数据,也会产生以下查询:

SELECT * FROM `posts` WHERE ( (`posts`.`type` = 'Project' OR `posts`.`type` = 'ProjectDesignWall' ) ) ORDER BY originally_created_at DESC
Run Code Online (Sandbox Code Playgroud)

有谁知道为什么会这样,有没有办法让它至少表现得一致,如果没有完全解决问题?

Rya*_*igg 5

因为在生产中,所有类都会立即加载.当所有类都加载时,它意识到ProjectDesignWall是Project的子类,因此收集了所有类.