我目前对我的用户组进行了以下迁移has_many:通过关联:
class CreateUserGroups < ActiveRecord::Migration
def change
create_table :user_groups do |t|
t.integer :user_id, :null => false
t.integer :group_id, :null => false
t.timestamps null: false
end
end
end
具有以下模型和唯一约束:
class UserGroup < ActiveRecord::Base
belongs_to :user
belongs_to :group
validates_uniqueness_of :user, :scope => :group, :message => :not_unique
end
唯一性验证运行良好,但是如果我的应用程序中的竞争线程导致争用条件并且它通过了应用程序级检查怎么办? 如何编写迁移以防止联接表中在数据库级别为用户和组出现重复行?
您需要添加唯一索引
add_index :user_groups, [:user_id, :group_id], unique: true