2

我有一些命名空间模型,我正在尝试为它们覆盖默认的 rails 表名,因为我正在连接到现有的旧数据库。

我的模型是:

/app/models/licenses.rb

  module Licenses
    def self.table_name_prefix
      ''
    end
  end

/app/models/licenses/employee.rb

class Licenses::Employee < ActiveRecord::Base
  establish_connection YAML::load(File.open("#{Rails.root}/config/licenses_database.yml"))[Rails.env]
  self.table_name = 'EMPLOYEE'
  self.primary_key = 'EMPLOYEE_ID'
end

/app/models/licenses/inspection.rb

class Licenses::Inspection < ActiveRecord::Base
  establish_connection YAML::load(File.open("#{Rails.root}/config/licenses_database.yml"))[Rails.env]
  self.table_name = 'INSPECTION'
  self.primary_key = 'INSPECTION_ID'
end

当我运行测试时,会生成错误

PG::Error: 错误:关系“licenses_employees”不存在

从命名空间模型中删除前缀是否缺少一些东西?

更新:我尝试将许可证模块中的表名前缀设置为“testing_”而不是“”,但我仍然收到相同的错误消息。

4

1 回答 1

3

手头的问题似乎是我使用 rails 生成器为现有数据库创建命名空间模型。生成器已将夹具文件创建为命名空间的夹具,即/test/fixtures/licenses/employees.yml. 当我尝试运行测试时,Rails 会尝试根据夹具名称/路径将夹具插入表中。我只需要移动现有数据库的夹具文件并重命名它们以匹配我在模型中设置的表名,即/test/fixtures/licenses/employee.yml.

于 2012-10-01T17:45:52.820 回答