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用于表的字段,相当于盖住字段数据的一部分.比如一 ...
随机推荐
- static,你还敢用吗?
我用火狐的HttpRequester测试开发组里一个同学发布的Web API接口,遇到了一个奇怪的问题. 我测试边界情况时,第一次调用响应的结果是正常的,但当再次及以后的请求时,却返回了异常“Syst ...
- Bootstrap3系列:导航
1. 标签页 .nav添加.nav-tabs设计标签页,.nav-tabs 依赖 .nav 基类. 1.1 示例代码 <ul class="nav nav-tabs"> ...
- ITTC数据挖掘平台介绍(四) 框架改进和新功能
本数据挖掘框架在这几个月的时间内,有了进一步的功能增强 一. 超大网络的画布显示虚拟化 如前几节所述,框架采用了三级层次实现,分别是数据,抽象Node和绘图的DataPoint,结构如下: ...
- 在ASP.NET Core Web API上使用Swagger提供API文档
我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...
- LCM性质 + 组合数 - HDU 5407 CRB and Candies
CRB and Candies Problem's Link Mean: 给定一个数n,求LCM(C(n,0),C(n,1),C(n,2)...C(n,n))的值,(n<=1e6). analy ...
- RabbitMQ Config
默认访问地址:http://localhost:15672/ 要想修改内网访问: %APPDATA%\RabbitMQ\ 目录下添加文件 rabbitmq.config [ {rabbit, [%% ...
- 【C#】无损转换Image为Icon
如题,市面上常见的方法是: var handle = bmp.GetHicon(); //得到图标句柄 return Icon.FromHandle(handle); //通过句柄得到图标 此法的问题 ...
- 【无私分享:ASP.NET CORE 项目实战】目录索引
简介 首先,我们的 [无私分享:从入门到精通ASP.NET MVC] 系列已经接近尾声,希望大家在这个过程中学到了一些思路和方法,而不仅仅是源码. 因为是第一次写博客,我感觉还是比较混乱的,其中 ...
- java基础知识 多线程
package org.base.practise9; import org.junit.Test; import java.awt.event.WindowAdapter; import java. ...
- Gradle project sync failed
在Android Studio中运行APP时出现了以下错误: gradle project sync failed. please fix your project and try again 解决的 ...