当前位置: 首页 > news >正文

SQLServer之创建数据库快照

创建数据库快照注意事项

语法:set transaction isolation level snapshot;

指定事务中任何语句读取的数据都将是在事务开始时便存在的数据的事务上一致的版本。 事务只能识别在其开始之前提交的数据修改。 在当前事务中执行的语句将看不到在当前事务开始以后由其他事务所做的数据修改。 其效果就好像事务中的语句获得了已提交数据的快照,因为该数据在事务开始时就存在。

除非正在恢复数据库,否则 SNAPSHOT 事务不会在读取数据时请求锁。 读取数据的 SNAPSHOT 事务不会阻止其他事务写入数据。 写入数据的事务也不会阻止 SNAPSHOT 事务读取数据。

在数据库恢复的回滚阶段,如果尝试读取由其他正在回滚的事务锁定的数据,则 SNAPSHOT 事务将请求一个锁。 在事务完成回滚之前,SNAPSHOT 事务会一直被阻塞。 当事务取得授权之后,便会立即释放锁。

必须将 ALLOW_SNAPSHOT_ISOLATION 数据库选项设置为 ON,才能开始一个使用 SNAPSHOT 隔离级别的事务。如果使用 SNAPSHOT 隔离级别的事务访问多个数据库中的数据,则必须在每个数据库中将 ALLOW_SNAPSHOT_ISOLATION 都设置为 ON。

不能将通过其他隔离级别开始的事务设置为 SNAPSHOT 隔离级别,否则将导致事务中止。 如果一个事务在 SNAPSHOT 隔离级别开始,则可以将它更改为另一个隔离级别,然后再返回 SNAPSHOT。 事务在第一次访问数据时启动。

在 SNAPSHOT 隔离级别下运行的事务可以查看由该事务所做的更改。 例如,如果事务对表执行 UPDATE,然后对同一个表发出 SELECT 语句,则修改后的数据将包含在结果集中。

在快照隔离模式下,事务中任何语句读取的 FILESTREAM 数据都将是在事务开始(而非语句开始)时便存在的数据的事务性一致版本。

使用T-SQL脚本创建数据库快照

第一步:开始一个读取会话和修改会话。

读取会话脚本:

--声明数据库使用
use testss;
go

--开启修改会话
begin transaction updatetran
update test1 set name='数据库快照' where id='1';
waitfor delay '00:00:10';
commit transaction
go

修改会话脚本:

--声明数据库使用
use testss;
go

--创建读取会话
begin transaction readtran
select * from test1 where id='1';
commit transaction;
go

第二步:首先执行读取会话脚本,查看读取结果并记录,方便与快照开启之后读取结果进行对比。

clipboard.png

第三步:修改读取会话脚本。

--声明数据库使用
use testss;
go

--开启数据库快照隔离
--alter database testss set allow_snapshot_isolation on;

--关闭数据库快照隔离
--alter database testss set allow_snapshot_isolation off;

--设置事务隔离级别
set transaction isolation level snapshot;

--创建读取会话
begin transaction readtran
select * from test1 where id='1';
commit transaction;
go

第四步:先执行修改脚本,再执行读取脚本。

修改脚本:依次显示修改脚本执行状态和执行结果。

clipboard.png

clipboard.png

读取脚本:依次显示读取脚本读取状态和读取结果。

clipboard.png

clipboard.png

第五步:结果分析:首先执行修改脚本,在修改脚本执行期间立即执行读取脚本,读取进程没有阻塞,直接读取到了修改事务开始之前的数据,当修改脚本执行完毕之后,再次执行读取脚本,读取进程并未发生阻塞,事务修改完成读取结果和事务修改执行期间读取结果不同,这说明数据库快照只能读取事务开始之前和结束之后的状态。

相关文章:

  • 集成ssm+shiro出现的 问题
  • shell脚本案例分享 - 业务系统日志自定义保留或删除需求
  • 比特币代码分析10 比特币中的工作量
  • Python正则表达式里的单行re.S和多行re.M模式
  • DOM: EVENT FLOW
  • 在windows10上利用Anaconda 搭建python3.6 + tensorflow环境
  • 修复win10无法双击打开txt文档.reg
  • JS的运行机制的总结!
  • 从SQL Server CloudDBA 看云数据库智能化
  • 夯实爪哇基础-数据类型,内存
  • Hibernate关联关系注解配置简单理解
  • 五大好用的开源MySQL管理工具推荐
  • day--42 前端基础小结
  • 【python】【基础】mac安装python3及pip
  • Using system view: sys.sysprocesses to check SqlServer's block and deadlock
  • 【跃迁之路】【477天】刻意练习系列236(2018.05.28)
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • Android系统模拟器绘制实现概述
  • CODING 缺陷管理功能正式开始公测
  • go语言学习初探(一)
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • JavaScript中的对象个人分享
  • Java到底能干嘛?
  • Laravel 实践之路: 数据库迁移与数据填充
  • Python 反序列化安全问题(二)
  • Selenium实战教程系列(二)---元素定位
  • SpriteKit 技巧之添加背景图片
  • zookeeper系列(七)实战分布式命名服务
  • 第三十一到第三十三天:我是精明的小卖家(一)
  • 规范化安全开发 KOA 手脚架
  • 简单实现一个textarea自适应高度
  • 使用API自动生成工具优化前端工作流
  • 我与Jetbrains的这些年
  • 线上 python http server profile 实践
  • 怎么把视频里的音乐提取出来
  • 长三角G60科创走廊智能驾驶产业联盟揭牌成立,近80家企业助力智能驾驶行业发展 ...
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • ​Z时代时尚SUV新宠:起亚赛图斯值不值得年轻人买?
  • #laravel 通过手动安装依赖PHPExcel#
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第5节(封闭类和Final方法)
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (转) Face-Resources
  • (转) ns2/nam与nam实现相关的文件
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)http协议
  • (转)创业的注意事项
  • (转)负载均衡,回话保持,cookie
  • ./configure,make,make install的作用
  • .gitignore文件设置了忽略但不生效
  • .htaccess 强制https 单独排除某个目录
  • .NET 发展历程
  • .net企业级架构实战之7——Spring.net整合Asp.net mvc
  • .NET轻量级ORM组件Dapper葵花宝典
  • ?