Nay*_*ish 5 ruby mysql concurrency ruby-on-rails ruby-on-rails-3
试图弄清楚如何在Ruby On Rails中处理并发性.
如何获取一段代码来锁定数据库中的行并在需要时强制回滚?
更具体地说,有没有办法强制某段代码完全完成,如果没有回滚?我希望将历史记录添加到项目中的事务中,并且我不希望事务在没有保存历史记录的情况下提交,因此如果服务器介于两个操作之间(保存事务并保存历史记录),则数据库可能会进入非法国家.
您想要查看ActiveRecord Transactions和Pessimistic Locking.
Account.transaction do
account = Account.find(account_id)
account.lock!
if account.balance >= 100
account.balance -= 100
account.save
end
end
Run Code Online (Sandbox Code Playgroud)