我有一个简单的模型:
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”?
答案 0 :(得分:5)
当Rails为连接表创建关联时,它希望模型按字母顺序排列。由于r出现在你之前,它会将其创建为roles_users
。
我建议您重命名连接表,或者,您可以将:join_table => "users_roles"
添加到两个关联中。