ROR中的数据库安全并发

Nay*_*ish 5 ruby mysql concurrency ruby-on-rails ruby-on-rails-3

试图弄清楚如何在Ruby On Rails中处理并发性.

如何获取一段代码来锁定数据库中的行并在需要时强制回滚?

更具体地说,有没有办法强制某段代码完全完成,如果没有回滚?我希望将历史记录添加到项目中的事务中,并且我不希望事务在没有保存历史记录的情况下提交,因此如果服务器介于两个操作之间(保存事务并保存历史记录),则数据库可能会进入非法国家.

Dou*_*rer 5

您想要查看ActiveRecord TransactionsPessimistic 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)