在Rails中HABTM和连接表的问题

时间:2010-07-20 08:48:22

标签: ruby-on-rails fixtures has-and-belongs-to-many

我有一个简单的模型:

class User < ActiveRecord::Base
   has_and_belongs_to_many :roles
end

class Role < ActiveRecord::Base
   has_and_belongs_to_many :users
end

我创建了一个简单的连接表:

class CreateUsersRoles < ActiveRecord::Migration
  def self.up
    create_table :users_roles, :id => false do |t|
      t.integer :user_id
      t.integer :role_id

      t.timestamps
    end
  end

  def self.down
    drop_table :users_roles
  end
end

迁移后,shema.rb正在关注:

create_table "roles", :force => true do |t|
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
end

create_table "users", :force => true do |t|
    t.string   "login"
    t.string   "password"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

create_table "users_roles", :id => false, :force => true do |t|
  t.integer  "user_id"
  t.integer  "role_id"
  t.datetime "created_at"
  t.datetime "updated_at"
end

这里的条目以相同的顺序显示,如“schema.rb”

我按照以下方式安排了灯具:

# roles.yml 
user:
  name: user

admin:
  name: admin

moderator:
  name: moderator

# users.yml
User1:
  login: User1
  password: User1
  roles: user

User2:
  login: User2
  password: User2
  roles: admin, moderator

User3:
  login: User3
  password: User3
  roles: moderator

并且出现了问题:在“rake db:fixtures:load”rails上抱怨连接表的名称:

  

SQLite3 :: SQLException:没有这样的表:roles_users:DELETE FROM“roles_users”WHERE 1 = 1

问题是 - 为什么它需要“roles_users”,而表格是“users_roles”?

1 个答案:

答案 0 :(得分:5)

当Rails为连接表创建关联时,它希望模型按字母顺序排列。由于r出现在你之前,它会将其创建为roles_users

我建议您重命名连接表,或者,您可以将:join_table => "users_roles"添加到两个关联中。