Sql Server 2016 新功能——内置的 Temporal Tables
放假之前老大跟我提起了一下2016有个有趣的功能叫 Temporal Table ,今天去看了一下资料整理一下。
这个功能看上去像是临时表,但是其实是系统维护的一个历史记录表。(在某个程度上面比起我们手动维护的历史表应该方便了一点的)
简单直接的说,它的界面看起来是这样的(就像是T1一样) 创建了之后,就会在下面有一个T1History的表中表来记录。
然后我们来试下怎么去玩这个功能。首先,确认你的Sql Server 版本是2016。然后我们通过一个这样的语句来创建表
Use Test
go create table T1(ID int identity primary key,
COl1 nvarchar(50),
TimeFrom datetime2 generated always as row start,
TimeTo datetime2 generated always as row end,
period for system_time(TimeFrom,TimeTo)) with (SYSTEM_VERSIONING = ON (HISTORY_TABLE = dbo.T1History));
这里我就简单的创建一个只有自增主键和一个列的表。创建System_Versioning 的表。必须有2个声明为datetime2 的时间字段才行,因为需要用这2个字段来记录数据的产生轨迹。
比如这里我是使用一个TimeFrom 的字段表示数据的作用开始时间,而TimeTo表示这行数据的失效时间(比方说数据被修改,被删除,那么TimeTo就会记录着修改,删除的时间)
下面我们进行测试,先做测试样例,然后再说明
Step 1:新增数据
insert into T1 (Col1)
values (''),(''),('') select * from T1
select * from T1History ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
1 1111 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999
2 2222 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999
3 3333 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999 (3 行受影响) ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
新增的时候,数据都是最新的版本,所以在历史表里面并不存在记录(注明一点,TimeFrom 和TimeTo 这2个字段将由系统控制维护,并不需要手工插入,如果显示写入这个字段,将抛出错误。系统维护这2个字段,采用的时间将使用UTC格式的时间,对于我们国内,就是小时-8的操作)
Step 2:修改数据
update T1 set Col1 = Col1+'New' where ID = 2 select * from T1
select * from T1History ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
1 1111 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999
2 2222New 2016-10-07 07:30:38.0561513 9999-12-31 23:59:59.9999999
3 3333 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999 ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
2 2222 2016-10-07 07:28:30.3598532 2016-10-07 07:30:38.0561513
修改数据的时候。将在历史表里面写入一条历史记录,并将TimeTo设置为当前修改的UTC时间,在主表将保留数据的最新版本。
Step 3:删除
delete from T1 where ID = 3
select * from T1
select * from T1History ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
1 1111 2016-10-07 07:28:30.3598532 9999-12-31 23:59:59.9999999
2 2222New 2016-10-07 07:30:38.0561513 9999-12-31 23:59:59.9999999 ID COl1 TimeFrom TimeTo
----------- -------------------------------------------------- --------------------------- ---------------------------
2 2222 2016-10-07 07:28:30.3598532 2016-10-07 07:30:38.0561513
3 3333 2016-10-07 07:28:30.3598532 2016-10-07 07:32:04.3640717
删除数据的时候和修改的机制差不多,就是主表删除了行记录,但是历史表保留了一份删除的动作。
简单的测试就可以做到这里。下面还有几个测试说明
1 如果使用Merge,那么Merge做的操作将对应以上的增/删/改来维护版本
2 使用了经版本维护的表之后,不能使用truncate table 的操作,因为操作不支持
3 drop 表的时候,不能直接使用drop table 语句,需要先用 ALTER TABLE [dbo].[T1] SET ( SYSTEM_VERSIONING = OFF ) 来把系统维护的版本去掉,然后再分别drop 掉当前表和历史表
4 我是凑数的╮(╯_╰)╭ ~请其他大神指导补充
5 谢谢@wy123 的提醒,创建这种类型的表需要有主键才行~居然忘记了
Sql Server 2016 新功能——内置的 Temporal Tables的更多相关文章
- Sql Server 2016新功能之 Row-Level Security
Sql Server 2016 有一个新功能叫 Row-Level Security ,大概意思是行版本的安全策略(原来我是个英语渣_(:з」∠)_) 直接上例子.这个功能相当通过对表添加一个函数作为 ...
- SQL Server ->> 深入探讨SQL Server 2016新特性之 --- Temporal Table(历史表)
原文:SQL Server ->> 深入探讨SQL Server 2016新特性之 --- Temporal Table(历史表) 作为SQL Server 2016(CTP3.x)的另一 ...
- SQL Server 2014新功能PPT
本篇文章是我在公司内部分享SQL Server 2014新功能的PPT,在本PPT中我详细描述了SQL Server除了BI方面的新功能,以及提供了大量的测试.希望对大家有帮助. 请点 ...
- SQL Server 2016新特性:列存储索引新特性
SQL Server 2016新特性:列存储索引新特性 行存储表可以有一个可更新的列存储索引,之前非聚集的列存储索引是只读的. 非聚集的列存储索引支持筛选条件. 在内存优化表中可以有一个列存储索引,可 ...
- SQL Server 2016新特性:DROP IF EXISTS
原文:SQL Server 2016新特性:DROP IF EXISTS 在我们写T-SQL要删除某个对象(表.存储过程等)时,一般会习惯先用IF语句判断该对象是否存在,然后DROP,比如: 旧 ...
- SQL Server ->> SQL Server 2016新特性之 --- Query Store
前言 SQL Server 2016引入新的查询语句性能监控.调试和优化工具/功能 -- Query Store.以前我们发现一条查询语句性能突然下降,我们要去找出问题的所在往往需要通过调用一些DMV ...
- SQL Server 2016新特性: 对JSON的支持
SQL Server 2005开始支持XML数据类型,提供原生的XML数据类型.XML索引及各种管理或输出XML格式的函数.随着JSON的流行,SQL Server2016开始支持JSON数据类 ...
- SQL Server ->> 深入探讨SQL Server 2016新特性之 --- Row-Level Security(行级别安全控制)
SQL Server 2016 CPT3中包含了一个新特性叫Row Level Security(RLS),允许数据库管理员根据业务需要依据客户端执行脚本的一些特性控制客户端能够访问的数据行,比如,我 ...
- SQL Server ->> SQL Server 2016新特性之 -- Dynamic Data Masking
Dynamic Data Masking是为了防止敏感数据暴露给未经授权的用户,以一种最小开销和维护成本的形式.Dynamic Data Masking用于表的字段,相当于盖住字段数据的一部分.比如一 ...
随机推荐
- 游戏编程系列[1]--游戏编程中RPC协议的使用
RPC(Remote Procedure Call Protocol)--远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC协议假定某些传输协议的存在 ...
- WCF学习之旅—WCF4.0中的简化配置功能(十五)
六 WCF4.0中的简化配置功能 WCF4.0为了简化服务配置,提供了默认的终结点.绑定和服务行为.也就是说,在开发WCF服务程序的时候,即使我们不提供显示的 服务终结点,WCF框架也能为我们的服务提 ...
- Apache thrift RPC 双向通信
在上一篇介绍Apache thrift 安装和使用,写了一个简单的demo,讲解thrift服务的发布和客户端调用,但只是单向的客户端发送消息,服务端接收消息.而客户端却得不到服务器的响应. 在不涉及 ...
- Bootstrap3系列:输入框组
1. 基本实例 通过在文本输入框 <input> 前面.后面或是两边加上文字或按钮,实现对表单控件的扩展. .input-group包含.input-group-addon给 .form- ...
- http程序接口、调用(最入门级,文末附Demo)
HTTP协议简介 既然是基于HTTP协议开发,那么就首先要了解下HTTP协议的相关内容- 在TCP/IP体系结构中,HTTP属于应用层协议,位于TCP/IP协议的顶层.浏览Web时,浏览器通过HTTP ...
- Beginners Guide To Web Development
Web Development Front End Development Back End Development
- 微信扫描下载提示以及js判断用户手机系统
今天抽空也写一下这个教程吧,这里面涉及到就是一个APP的页面下载.公司有这个需求,让做一个页面,就是二维码扫描下载.一开始我做的版本是只能是通过浏览器来下载的,但是实际应用中,很多用户 ...
- kafka性能参数和压力测试揭秘
转自:http://blog.csdn.net/stark_summer/article/details/50203133 上一篇文章介绍了Kafka在设计上是如何来保证高时效.大吞吐量的,主要的内容 ...
- 代码的坏味道(7)——临时字段(Temporary Field)
坏味道--临时字段(Temporary Field) 特征 临时字段的值只在特定环境下有意义,离开这个环境,它们就什么也不是了. 问题原因 有时你会看到这样的对象:其内某个实例变量仅为某种特定情况而设 ...
- Basic Tutorials of Redis(4) -Set
This post will introduce you to some usages of Set in Redis.The Set is a unordered set,it means that ...