The insert operation does not cause a row version to be generated because there is really no prvious version of the row being inserted.

both deleted and update operations lead to row versions.

demo:

USE master

GO

-------------------------------------------------------------------

--创建SnapTestDB数据库,并将数据库开启READ_COMMITTED_SNAPSHOT

--和ALLOW_SNAPSHOT_ISOLATION选项

CREATE DATABASE SnapTestDB

GO

ALTER DATABASE SnapTestDB SET READ_COMMITTED_SNAPSHOT ON

GO

ALTER DATABASE SnapTestDB SET ALLOW_SNAPSHOT_ISOLATION ON

GO

---------------------------------------------------------------------

--检查数据库快照设置

SELECT

DB.is_read_committed_snapshot_on,

DB.snapshot_isolation_state_desc,

DB.snapshot_isolation_state

FROM sys.databases DB

WHERE DB.name ='SnapTestDB'

----------------------------------------------------------------------

--创建测试表SnapTestDB.dbo.Test1

USE SnapTestDB

GO

CREATE TABLE SnapTestDB.dbo.Test1(C1 INT,C2 INT)

GO

----------------------------------------------------------------------

--测试在插入时是否会有版本数据

BEGIN TRAN TR1

INSERT SnapTestDB.dbo.Test1(C1,C2)

SELECT 1,1

UNION ALL

SELECT 2,2

SELECT COUNT(1) FROM sys.dm_tran_version_store VS

WHERE VS.database_id=DB_ID('SnapTestDB')

COMMIT

--测试结果:会产生版本数据

----------------------------------------------------------------------

--测试在更新时是否会有版本数据

BEGIN TRAN TR1

UPDATE SnapTestDB.dbo.Test1

SET C1=0

SELECT COUNT(1) FROM sys.dm_tran_version_store VS

WHERE VS.database_id=DB_ID('SnapTestDB')

COMMIT

--测试结果:会产生版本数据

----------------------------------------------------------------------

--测试在更新时是否会有版本数据

BEGIN TRAN TR1

DELETE FROM SnapTestDB.dbo.Test1

WHERE C1=0

SELECT COUNT(1) FROM sys.dm_tran_version_store VS

WHERE VS.database_id=DB_ID('SnapTestDB')

COMMIT

--测试结果:会产生版本数据

----------------------------------------------------------------------

--总结

--在READ_COMMITTED_SNAPSHOT下,由于在TempDB中保存了版本数据,

--因此SELECT不会被其他事务的UPDATE或DELETE所阻塞,从而提高了并发性,

--但也因此加重了TempDB的压力

--只有DELETE和UPDATE才会引发版本数据,版本数据存放在TmepDB中,SQL Server

--会智能地周期性移除那些无用的版本数据,移除版本数据会有一定延迟(不是立即移除无用的版本数据)

--如果版本数据被一个事务使用且该事务长时间未提交,会导致TempDB的占用空间迅速暴增,因此应尽量缩短事务

Tempdb--Snapshot的更多相关文章

  1. 数据库的快照隔离级别(Snapshot Isolation)

    隔离级别定义事务处理数据读取操作的隔离程度,在SQL Server中,隔离级别只会影响读操作申请的共享锁(Shared Lock),而不会影响写操作申请的互斥锁(Exclusive Lock),隔离级 ...

  2. Expert 诊断优化系列------------------给TempDB 降温

    前面文章针对CPU.内存.磁盘.语句.等待讲述了SQL SERVER的一些基本的问题诊断与调优方式.为了方便阅读给出导读文章链接方便阅读: SQL SERVER全面优化-------Expert fo ...

  3. 第23/24周 临时数据库(TempDb)

    在今天的性能调优培训里我们讨论下TempDb——SQL Server的公共厕所,在SQL Server里我是这样描述它的.我们的每个人都会经常使用TempDb.有些人直接使用它,有些人不直接使用它.今 ...

  4. SQL server performance - tempdb

    When tempdb is used? User objects: User-defined tables and indexes System tables and indexes Global ...

  5. SQL Server 2008性能故障排查(四)——TempDB

    原文:SQL Server 2008性能故障排查(四)--TempDB 接着上一章:I/O TempDB: TempDB是一个全局数据库,存储内部和用户对象还有零食表.对象.在SQLServer操作过 ...

  6. SQL Server中TempDB管理(版本存储区的一个example)

    原文:SQL Server中TempDB管理(版本存储区的一个example) 原文来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive ...

  7. 监测谁用了SQL Server的Tempdb空间

    原文:监测谁用了SQL Server的Tempdb空间 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/02/11/sql-server-tempdb. ...

  8. Tempdb怎么会成为性能瓶颈

    原文:Tempdb怎么会成为性能瓶颈 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/25/tempdb.aspx 我曾经遇到过这样一个性能问题. ...

  9. SQL Server-聚焦SNAPSHOT基于行版本隔离级别详解(三十)

    前言 上一篇SQL Server详细讲解了隔离级别,但是对基于行版本中的SNAPSHOT隔离级别仍未完全理解,本节再详细讲解下,若有疑义或不同见解请在评论中提出,一起探讨. SNAPSHOT行版本隔离 ...

  10. [转]如何监测谁用了SQL Server的Tempdb空间

    Tempdb 系统数据库是一个全局资源,供连接到 SQL Server 实例的所有用户使用.在现在的SQL Server里,其使用频率可能会超过用户的想象.如果Tempdb空间耗尽,许多操作将不能完成 ...

随机推荐

  1. VCS常用指令

    常用命令介绍 对VCS的常用命令进行介绍,便于工程师进行日常维护.本手册描述的命令仅供参考,具体描述请以Veritas公司提供的相关资料为准. VCS的安装和命令都在下列目录下:sbin, /usr/ ...

  2. 第 0 课 Golang环境搭建

    1  下载 https://studygolang.com/dl  2   安装完成后,查看环境变量 GOBIN 存放可执行文件的目录的绝对路径. GOPATH 工作区目录的绝对路径.存放远源码的路径 ...

  3. 使用JdbcTemplate访问数据库

    参考源端:https://blog.csdn.net/liaodehong/article/details/76974827 今天用Spring Boot访问一下数据库,并且把数据返回到页面中,进行增 ...

  4. MVC框架介绍

    第一,建立一个解决方案然后在该解决方案下面新建mvc空项目. 第二,下面先对该项目的一些文件进行介绍: MVC项目文件夹说明: 1.(App_Data):用来保存数据文件,比如XML文件等 2.(Ap ...

  5. Python中的strip()函数的用法

    函数:string.strip() Python strip() 方法用于移除字符串头尾指定的字符(默认为空格). 一.函数说明 strip() 语法:str.strip([rm]); 参数说明 rm ...

  6. k8s问题记录

    1. kubectl run 起来的pod 用 kubectl delete po删不掉 kubectl delete deployment my-nginx kubelet# 看到最后一行:erro ...

  7. FP变更物料编码(增加尾缀)

    FP物料编码增加尾缀的程序,标准物料编码是18位,目前程序中增加尾缀的有三种1.DUMMY 2.SP开头 3.P开头 4.C开头 5.BP对应处理程序如下:1.DUMMY       SAP_MATE ...

  8. JSP中系统Date的几点不符合中国时间观的地方

    正常调用系统时间的显示格式是Date date = new Date 显示出来的当前时间为Sun Nov 22 18:39:51 CST 2015 星期天的英文单词是Sun, 这个大家都是熟悉的, 这 ...

  9. Spring的Cache注解

    Spring的Cache注解如下所示: @CacheConfig:主要用于配置该类中会用到的一些共用的缓存配置.在这里@CacheConfig(cacheNames = "users&quo ...

  10. SQL server2008零基础学习

    SQL 基础 数据库简介: 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,它产生于距今五十年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管 ...