经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
数据库事务的四种隔离模式
来源:cnblogs  作者:工藤新一迷  时间:2019/9/26 9:01:08  对本文有异议

四种隔离模式主要是用来解决不同线程的事务造成的几种问题:

1.修改丢失:两个事务A,B对同一数据同时进行读取与修改,出现事务B 覆盖事务A的提交结果

2.脏读:事务A读到事务B修改却未提交的数据,事务B回滚数据修改操作,导致了事务A获得数据是脏数据(也可以理解为事务A获取的数据与数据库中存储的数据是不一致的)

3.(不可重复读)虚读:事务A先读取某一行数据,事务B对改行数据进行修改,事务B再一次读取该行数据时就会造成前后两次读取结果不一致。

4.幻读:事务A读取某段数据,事务B对其进行插入或者删除操作时,当事务A重新读取该段数据时会造成前后两次查询的数据不一致,出现第一次比第二次多或者少的现象。

为了解决上面的问题,出现了四种事务隔离模式

1.Read uncommitted(未授权读取、读未提交):(排他写锁)同一时间只允许一个事务进行写操作的存在,可以允许多个事务进行读取。可以解决(修改丢失)的问题,但是会出现脏读,虚读,幻读这些问题

2.Read committed(授权读取、读提交):(排他写锁、瞬间共享读锁)同一时间只允许一个事务进行写操作禁止其他事务进行读与写,可以解决(修改丢失,脏读)不能解决虚读,幻读

3.Repeatable read(可重复读取):(排他写锁、共享读锁)同一时间只允许一个事务进行写操作禁止其他事务进行读与写,同一时间一个事务读取的时不允许其他事务进行写(可以读取)。可以解决(修改丢失,脏读,虚读),但不能解决幻读。

4.序列化:事务只能一个一个按照序列来进行读写,这样并发性性能不高,可以解决上面4个问题。

原文链接:http://www.cnblogs.com/ynwxownd/p/11587475.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号