使用数据库时,通常必须使用事务.比方说,我想将一定数量的资金从账户A转移到账户B.这涉及两个问题:
>减少账户A的钱
>在帐户B中增加它.
从理论上讲,我可以单独进行查询,但会发生错误.因此,可以肯定的是,我可以在事务中打包两个查询,并确保两个操作都定期结束或根本没有任何更改.没有钱消失或被创造.
问题是,在我看来,这只会将责任从我转移到数据库供应商.现在由数据库来完成两个操作,并确保两者都已完成或没有任何更改.数据库开发人员面临着发生错误的相同问题.
What techniques do database vendors use to ensure safety for transactions?
解决方法
维基百科上的
ACID – Implementations页面将帮助您开始预写日志记录,影子分页和多版本并发控制.点击链接查找更多信息.
每个DBMS供应商都实现自己的算法,通常是几个不同的算法,具体取决于上下文,完整的ACID或宽松的要求,分布式事务一致性要求等……