首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据库中的读写锁

数据库中的读写锁
EN

Stack Overflow用户
提问于 2012-11-22 18:50:54
回答 1查看 484关注 0票数 1

根据关于database isolation级别的维基文档,4个不同的级别匹配不同的锁配置。

但是锁本身是什么呢?数据库是否提供了这种读写锁定机制,或者读写锁定只是基于隔离级别和提交的抽象?

如果能得到这个隔离级别是如何在数据库中工作的详细描述,那就太好了。对这件事要有一点耐心。谢谢。

EN

回答 1

Stack Overflow用户

发布于 2013-02-27 20:52:39

隔离级别是对如何提供同时访问和更改数据库中数据的透明方式的抽象。如果您的数据库能够隔离,则不同的场景不会导致状态不一致。

例如:假设有一个银行账户数据库。为了简单起见,只需想象一个有两行的表,一个帐号和一个总余额。

现在,如果有人将一些钱从帐户1转移到帐户2进程1,而同时其他人将资金从帐户2转移到帐户3进程2,会发生什么?假设1首先读取帐户1和2的总和。然后,轮到2 get并完全执行。%1现在使用的是过时的值,因此将帐户%2的合计设置为错误的值。

对于事务,%2必须等到%1完成整个过程。通常这是使用锁实现的,因此数据库会锁定1到目前为止使用的所有内容。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13511113

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档