微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

mysql – ROR中的数据库安全并发

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

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

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

解决方法:

你想看看ActiveRecord TransactionsPessimistic Locking.

Account.transaction do
  account = Account.find(account_id)
  account.lock!

  if account.balance >= 100
    account.balance -= 100
    account.save
  end
end

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐