我试图在我的一个表格字段中强制实现值的唯一性.更改表不是一个选项.我需要使用ActiveRecord有条件地在表中插入一行,但我担心同步.
在Rails ActiveRecord中first_or_create是否防止竞争条件?
def first_or_create(attributes = nil,options = {},&block) first || create(attributes,options,&block) end
由于多个进程的同步问题,重复的条目是否可能导致数据库?
解决方法
是的,这是可能的.
您可以大大减少与optimistic或pessimistic locking冲突的机会.当然,乐观锁定需要向表格添加一个字段,悲观锁定也不会缩放 – 另外,这取决于您的数据存储的功能.
我不知道你是否需要额外的保护,但是它是可用的.