[译]SQL SERVER 2016 – Temporal Tables

原文

Temporal Table是SQL Server2016的新特性。能存储你表里面任意时间点的数据信息。 换句话说,如果你针对一张表执行任何更新或者删除操作,老数据会被新数据覆盖,下次查询的时候是查的最新的数据,但如果使用了temporal table你可以查询到任意时间点的数据。

Temporal table是如何工作的呢?

当你往Temporal table插入记录的时候会发生什么?

当你往temporal table插入数据的时候,数据会留在temporal table中,但是不会影响history table。

702742-20180208095631029-1408376410.png

当你更新或者删除Temporal table的数据时会发生什么?

当你更新或者删除Temporal table的数据时,已存在的记录会先被移动到history table中,记录temporal table数据的改变。

702742-20180208095946295-796246366.png

当你查询Temporal table的时候会发生什么?

当你查询temporal table的时候, temporal table会自己决定是从temporal table中还是从history table中返回数据,你不应该使用任何join关联temporal table和history table进行查询。

702742-20180208100235076-1659416680.png

创建Temporal Table

创建temporal table时,其对应的history table会自动创建(如果你已经有了一个history table,你可以将他和temporal table关联起来)。下面是一个普通的创建表的脚本,但是有些额外特殊的列。这些列用来定义temporal table的period definition,并且这些列是隐藏的。当你查询的时候这些列不会出现在结果集中。脚本中还将history table名指定为“dbo.tbl_Product_History”。当然你也可以不声明history table的名字,SQL会自动为temporal table创建一个默认的history table。

CREATE DATABASE SampleDB
GO
USE SampleDB
GO
--DROP TABLE tbl_Product
--GO
CREATE TABLE tbl_Product
(Product_ID int NOT NULL PRIMARY KEY CLUSTERED,Product_Name varchar(50) NOT NULL,Rate numeric(18,2),/*Temporal Specific Fields - Period Definition */[Valid From] datetime2 GENERATED ALWAYS AS ROW START HIDDEN NOT NULL,[Valid Till] datetime2 GENERATED ALWAYS AS ROW END HIDDEN NOT NULL,PERIOD FOR SYSTEM_TIME ([Valid From] ,[Valid Till])
)
WITH
/* Temporal Specific - System-Versioning Configuration*/
(SYSTEM_VERSIONING = ON(HISTORY_TABLE = dbo.tbl_Product_History, DATA_CONSISTENCY_CHECK = ON)
);
GO

702742-20180208101237404-1172849819.png

执行insert

之前说过,当你对一个temporal table执行insert语句,不会影响history table。下面我们执行insert,然后看看相应的结果。

USE SampleDB
GO
INSERT INTO dbo.tbl_Product VALUES(1,'Product A', 300)
,(2,'Product B', 400)
GOSELECT * FROM tbl_Product
GO
SELECT * FROM dbo.tbl_Product_History
GO

702742-20180208101542701-1993309391.png

执行update

当你对一个temporal table执行update语句,老数据会被移到history table中,temporal table会保存最新的数据。下面我们执行update,然后看看相应的结果。

USE SampleDB
GO
UPDATE tbl_Product SET Rate =Rate/2
WHERE Product_ID IN (1,2)
GOSELECT * FROM tbl_Product
GO
SELECT * FROM dbo.tbl_Product_History
GO

702742-20180208102123326-1652402508.png

执行delete

当你对一个temporal table执行delete语句,老数据会被移到history table中,temporal table会保存最新的数据。下面我们执行delete,然后看看相应的结果。

USE SampleDB
GO
DELETE FROM tbl_Product WHERE Product_ID = 2
GOSELECT * FROM tbl_Product
GO
SELECT * FROM dbo.tbl_Product_History
GO

702742-20180208102239576-2041470871.png

执行select

在temporal table中执行select非常有意思。

下面的脚本和正常的table一样返回table最新的结果集:

USE SampleDB
GO
--Current State of the table
SELECT * FROM tbl_Product
GO

702742-20180208102724357-2018826372.png

下面使用FOR SYSTEM_TIME ‘2015-06-27 21:33:50.9002439’来查询temporal table,这将返回这个表在‘2015-06-27 21:33:50.9002439’ 时的状态。

USE SampleDB
GO
SELECT * FROM tbl_Product
FOR SYSTEM_TIME AS OF '2015-06-27 21:33:50.9002439'
GO

702742-20180208102922185-1292388599.png

下面使用FOR SYSTEM_TIME at ‘2015-06-27 21:43:31.2982847’来查询temporal table,这将返回这个表在‘2015-06-27 21:43:31.2982847’时的状态。

USE SampleDB
GO
SELECT * FROM tbl_Product
FOR SYSTEM_TIME AS OF '2015-06-27 21:43:31.2982847'
GO

702742-20180208103059545-1506427716.png

总结

有了temporal table,将改变我们为数据仓库设计数据库的方式。因为我们不需要创建一个独立的audit表通过触发器或者存储过程记录数据的变化,temporal table自动为我们完成了这些工作。

转载于:https://www.cnblogs.com/irocker/p/sql-server-2016-temporal-tables.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/414720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

拦截器、过滤器、@Aspect 区别

1、需求场景 之前也有在文章写道 “拦截器\过滤器" 的区别,文章链接,在实际开发过程中,我们可能会遇到拦截请求参数的需求,在这我举个场景。某一个接口的请求参数都是加密的,而请求参中还有一些跟业务无关的数据&…

工作231:给input动态赋值

这个应该是不可以的,必须重新使用用文件对话框选择。 这是处于安全的考虑,不能直接对input typefile的类型赋值,因为直接用JS就可以将你本地文件直接取到指定地点,就没有安全性可言。 因此必须对一个input typefile设置一个按钮来…

MyEclipse2015Stable2.0安装破解

java开发者不可避免需要使用到的开发工具——myeclipse2015。下载安装直接打开使用的话,使用期为30天,之后如果没有注册吗注册,就使用不了了。即使卸载重装还是提示试用期期限超限,无法打开使用。 于是就有了破解myeclipse2015方…

laravel5.5中间件

目录 1. 中间件知识1. artisan 命令2. 文件内容3. 前置中间件和后置中间件4. 使用中间件2. 控制器中间件1. 中间件知识 1. artisan 命令 php artisan make:middleware CheckAge 2. 文件内容 <?phpnamespace App\Http\Middleware;use Closure;class CheckAge {public functi…

JAVA spring 常用包作用详解(转)

转载地址&#xff1a;https://www.cnblogs.com/Tmc-Blog/p/6093162.html <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http:…

关于HttpUrlConnection网络请求之返回结果的中文乱码解决方法

解决方法&#xff1a; 原使用 StringBuffer改为使用StringBuilder即可 /** * 获取响应码 200成功 * 当响应成功&#xff0c;获取响应的流 */ int res conn.getResponseCode(); if(res…

日志汇总:logging、logger

目录 1、日志输出到文件 2、日志输出到屏幕 3、设置输出等级 4、设置多个日志输出对象 5、日志的配置 6、记录异常 7、设置日志输出样式1、日志输出到文件basicConfig()提供了非常便捷的方式让你配置logging模块并马上开始使用。什么都不配置直接使用默认值在控制台中打log&…

1、jeecg 笔记开篇

1. 前言 终究还是入了 jeecg 的 "坑"&#xff0c;国庆后公司采用该框架开发&#xff0c;故开篇记录。 虽说入"坑"&#xff0c;但不得不承认 jeecg 确实是一个非常强大的平台。 其实近几年凡是知名的开源框架都是采用代码生成器了&#xff0c;所以 jeecg 同…

工作233:定义有对话框的按钮

<!--定义一个有按钮的对话框 相当于dialog和按钮组合使用--> <template><!-- 有按钮的对话框 这个位置的代码会被包裹过去--><!--close-on-click-modal 是否可以通过点击 modal 关闭 Dialog append-to-body控制不能出现遮挡层--><el-dialog:title&q…

Android 上传图片实例,java上传图片接口

1、完整上传图片代码方法&#xff1a; private static final int TIME_OUT 10*1000; //超时时间 private static final String CHARSET "utf-8"; //设置编码 /*** android上传文件到服务器* param file 需要上传的文件* param RequestURL 请求的rul* return …

数据库日期时间显示在页面上格式错误的解决方案

做项目过程中肯定会碰到这样一个问题&#xff1a;在数据库中存的是date或datetime类型的值&#xff0c;从数据库里取出来遍历到页面上显示的是long类型或是GTM类型的日期时间。对于这个问题&#xff0c;经过研究之后有以下结论&#xff1a; 1.hibernate不会出现这样的问题&…

2、jeecg 笔记之 t:dictSelect 或 t:dgCol 自定义字典

1、需求 先说一下需求场景吧&#xff0c;我们知道 jeecg 中提供了下拉&#xff0c;其中包含两种使用场景&#xff1b; 一种是直接通过 t:dictSelect 使用&#xff0c;再就是 t:dgCol 用于表头的列表工具条标签&#xff1b; 总之就是这个样子 需求来了&#xff0c;我们想要下拉…

工作234:按钮禁用

<!--定义一个有按钮的对话框 相当于dialog和按钮组合使用--> <template><!-- 有按钮的对话框 这个位置的代码会被包裹过去--><!--close-on-click-modal 是否可以通过点击 modal 关闭 Dialog append-to-body控制不能出现遮挡层--><el-dialog:title&q…

android动态切换logo和label

注&#xff1a;更新版本时。需换为默认的才可以更新apk android:enabled"true"为默认 1、准备资源 &#xff08;1&#xff09;logo和名称资源 <string name"app_name">httpheader</string> <string name"app_name1">第二名&…

洛谷 P4016 负载平衡问题 【最小费用最大流】

求出平均数sum&#xff0c;对于大于sum的点连接(s,i,a[i]-sum,0)&#xff0c;表示这个点可以流出多余的部分&#xff0c;对于小于sum的点连接(i,t,sum-a[i],0)表示这个点可以接受少的部分&#xff0c;然后每个点向相邻的两个点连(i,j,inf,1)表示可以任意转移&#xff0c;每转移…

3、jeecg 笔记之 模糊查询

1、前言 jeecg 考虑到默认模糊查询的话&#xff0c;会增加系统压力&#xff0c;导致查询慢&#xff0c;本来系统就挺那啥的... 2、方式一之实体赋值 实体重新赋值查询&#xff0c;用 * %% * 实现&#xff0c;我们知道 sql 中通常使用 % 去模糊查询的&#xff0c;jeecg 中 datag…

工作235:splice

const user res.data.user;const dept user.department;console.log(dept.property)const properties dept.property.split(",");console.log(properties) 运行结果

java打印三角形,菱形。任意边长大小

一、等腰三角形 for (int j 0; j < num; j) { if (j > 0) { for (int i 0; i < j; i) { if (i j - 1) { for (int k 0; k < num - j; k) { if (k num - j - 1) { Syst…

django-form and fields validation

参考资料 清除数据与表单验证 清除数据时会进行表单验证。 在表格处理时有三种clean方法可调用&#xff0c;通常是在对表单调用is_valid()时执行。clean响应&#xff1a;一般有两种结果&#xff0c;如果处理的数据有问题&#xff0c;则抛出ValidationError错误信息&#xff1b;…

1、vue 笔记之 组件

1、组件个人理解&#xff1a; <组件>是页面的一部分&#xff0c;将界面切分成部分&#xff0c;每部分称为 <组件>2、组件化思想&#xff1a; //2.1、定义一个全局的组件&#xff0c;组件支持‘驼峰命名’规则Vue.component("TodoItem",{props: [content]…