实例演示SQL Server中五个事务隔离的区别
园子里有很不错的介绍SQL Server事务隔离的文章,感觉很多都从概念入手介绍的,对那些初学者来说,看得见摸得着的理解才深刻,故不再重复,重点在于实例演示上面。 首先解释下事务隔离是干什么的,一个事务的隔离级别控制了它怎么样影响其它事务和被其它事务
园子里有很不错的介绍SQL Server事务隔离的文章,感觉很多都从概念入手介绍的,对那些初学者来说,看得见摸得着的理解才深刻,故不再重复,重点在于实例演示上面。
首先解释下事务隔离是干什么的,一个事务的隔离级别控制了它怎么样影响其它事务和被其它事务所影响。
1.READ UNCOMMITTED,会导致脏读(能读取其它事务没有提交的更改)和不可重复读(事务读取的数据被其它事务所修改,再次读取时不一致)
初始化:
(1,1), val int) INSERT INTO TranLevel(val) values(1) INSERT INTO TranLevel(val) values(2) INSERT INTO TranLevel(val) values(3)
首先执行Query1,再新建查询立即执行Query2
Query1:
BEGIN TRAN Query1 TranLevel DELAY Query1
Query2:
Query2 Tranlevel DELAY TranLevel COMMIT TRAN Query2
下面就看看Query2执行的结果是怎样的:
结果显而易见,美国空间,如果将事务隔离级别设置为未提交读,则会造成脏读和不可重复读的问题,在这几个事务隔离级别中是限制最小的一个,SQL Server分配的资源也最小。
2.READ COMMITTED,虚拟主机,提交读,默认的事务隔离级别,会造成不可重复读。
初始化:
drop Table tranlevel (1,1), val int) INSERT INTO TranLevel(val) values(1) INSERT INTO TranLevel(val) values(2) INSERT INTO TranLevel(val) values(3)
Query3:
Query3 DELAY TranLevel Query3
Query 4:
Query4 TranLevel DELAY TranLevel COMMIT TRAN Query4
执行Query3后,新建查询执行Query4。下面看看Querry4查询得到的数据。
结果就是Query4中的事务查询获得了在Query3提交后的数据,在同一事务中读取的数据不一致,造成了不可重复读。
3.REPEATABLE READ,会锁住那些事务访问的数据行,但不能防止新行的插入,所以会导致幻读。
初始化:
drop Table tranlevel (1,1), val int) INSERT INTO TranLevel(val) values(1) INSERT INTO TranLevel(val) values(2) INSERT INTO TranLevel(val) values(3)
Query5:
Query5 DELAY TranLevel(val) values(4) COMMIT TRAN Query5
Query6:
Query6 TranLevel TranLevel COMMIT TRAN Query6
执行Query5后,新建查询执行Query6。下面看看Querry6查询得到的数据:
可以看到,服务器空间,即使设置为可重复读,仍然会导致在同一事务中查询的数据不一致的情况,即幻读。
4.SHNAPSHOT 和 SERIALIZABLE 能解决脏读、不可重复读、幻读的问题,就没有必要再写实例来说明了。SHNAPSHOT级别对并发情况采用乐观处理,如果两个事务同时修改了一行数据,则后尝试修改的事务会爆冲突,但如果修改的是不同行,则不会有这个问题。如果不理解的朋友可以参考下面这个链接:
实例sql语句下载地址:

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在 Photoshop 中导出带密码保护的 PDF:打开图像文件。点击“文件”>“导出”>“导出为 PDF”。设置“安全性”选项,两次输入相同的密码。点击“导出”生成 PDF 文件。

CentOS 和 Ubuntu 的关键差异在于:起源(CentOS 源自 Red Hat,面向企业;Ubuntu 源自 Debian,面向个人)、包管理(CentOS 使用 yum,注重稳定;Ubuntu 使用 apt,更新频率高)、支持周期(CentOS 提供 10 年支持,Ubuntu 提供 5 年 LTS 支持)、社区支持(CentOS 侧重稳定,Ubuntu 提供广泛教程和文档)、用途(CentOS 偏向服务器,Ubuntu 适用于服务器和桌面),其他差异包括安装精简度(CentOS 精

H5、小程序和APP的主要区别在于:技术架构:H5基于网页技术,小程序和APP为独立应用程序。体验和功能:H5轻便易用,功能受限;小程序轻量级,交互性好;APP功能强大,体验流畅。兼容性:H5跨平台兼容,小程序和APP受平台限制。开发成本:H5开发成本低,小程序中等,APP最高。适用场景:H5适合信息展示,小程序适合轻量化应用,APP适合复杂功能应用。

在router文件夹下的index.js文件中注册VueRouter的必要性在开发Vue应用程序时,常常会遇到关于路由配置的问题。特�...

DOM节点下XPath查找方法详解在JavaScript中,我们经常需要根据XPath表达式从DOM树中查找特定的节点。如果需要从某�...

Laravel 和 ThinkPHP 都是流行的 PHP 框架,在开发中各有优缺点。本文将深入比较这两者,重点介绍它们的架构、特性和性能差异,以帮助开发者根据其特定项目需求做出明智的选择。

不同数据库系统添加列的语法为:mysql:alter table table_name add column_name data_type; postgresql:alter table table_name添加column_name data_type; oracle; oracle:alter table table_name add(column_name data_type)

CentOS防火墙的状态可以通过sudo firewall-cmd --state命令查看,返回running或not running。更详细的信息可以使用sudo firewall-cmd --list-all查看,包括已配置的区域、服务、端口等。如果 firewall-cmd 无法解决问题,可以使用sudo iptables -L -n查看iptables规则。修改防火墙配置前请务必做好备份,以确保服务器安全性。
