refer:

https://blog.csdn.net/Hehuyi_In/article/details/89670462

https://docs.microsoft.com/en-us/sql/relational-databases/tables/temporal-tables?view=sql-server-ver15

https://docs.microsoft.com/en-us/sql/relational-databases/tables/temporal-table-usage-scenarios?view=sql-server-ver15https://docs.microsoft.com/en-us/sql/relational-databases/tables/temporal-table-usage-scenarios?redirectedfrom=MSDN&view=sql-server-ver15

ef 目前不支持哦 (https://github.com/dotnet/efcore/issues/4693)

https://blog.51cto.com/zhouhuo/1980310

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

temporal table 是 2016 后有的.

目的是做 history 管理.

数据嘛, 一直 update delete. 有时候发现问题想 check back history 从前我们需要自己维护, 设计表记入资料等等.

挺麻烦的,而已也没有规范.

好像是 2011 年后有个规范了. 然后 2016 sql server 就实现了这个规范. 就是这个 temporal table 了。

这个 version control 的机制实现方法就是为一个表做多一个 history 表

当原表发生修改时, 就计入到 history 表里面. 除了多一个表以外, 还有 2 个重要的 column 是 SysStartTime 和 SysEndTime

通过时间管理, 就可以还原任何时间点的数据快照了。

结构有了之后就是语句啦. sql server 有一些特定的语法可以轻松的 query 出历史数据.

做业务开发的我们不需要懂底层太多, history sql server 会自己维护, 我们 query 的时候也是通过特定语法直接从主表查询. 所以基本上对 history 表是没有什么感知的.

下面来试试看 :

首先 management studio 没有 ui 可以直接创建 temporal table. 但是它可以做一个 template query 来弄.

这里我简单写点测试就好

创建一个表

create table dbo.Abc
(
Id int not null IDENTITY(1,1) PRIMARY KEY CLUSTERED ,
name nvarchar(120) not null,
age int not null,
SysStartTime datetime2 GENERATED ALWAYS AS ROW START,
SysEndTime datetime2 GENERATED ALWAYS AS ROW END,
PERIOD FOR SYSTEM_TIME (SysStartTime, SysEndTime)
)
with (system_versioning = on (history_table = dbo.AbcHistory));

SysStartTime 和 SysEndTime 是必须的, 然后它是 datetime2 UTC 时间, 不可以设置成 datetimeoffset

如果想依据 timezone 来查询, 可以参考 https://docs.microsoft.com/en-us/sql/relational-databases/tables/temporal-table-usage-scenarios?redirectedfrom=MSDN&view=sql-server-ver15

来试试跑些语句

insert into dbo.Abc (name, age) values ('keatkeat', 11);
update Abc set name = 'tamade' where Id = 1;
update Abc set name = 'tamade' where Id = 1;

insert 之后, start time 是当前时间, end time 是 9999 年, history 不会有任何资料

update 之后 start time 就更新了, 然后 history 就出现了一条 row, 这条 row 有之前的 value keatkeat 和 那个 row 的 start time, end time 就是当前.

再 update 多一次的话 (哪怕没有改到) history 也是会多一条 row 的, 时间 formula 和上面一样.

delete 和 update 差不多, hisotry 多一条 row.

-- 主表的 end time 不知道有什么用, delete by used 怎样记入呢

查询的话很简单, 对主表 query 加上时间就可以了

指定时间

select * from Abc for system_time as of '2020-12-29 08:32:51.5585273'

多个指定时间

select * from Abc for system_time contained in ('2020-12-29 08:32:51.5585273', 2020-12-29 08:35:51.5585273)

between

select * from Abc for system_time between '2020-12-29 08:32:51.5585273' and '2020-12-30 08:32:51.5585273';

要 drop table 的话需要先 off

alter table dbo.Abc set (system_versioning = off);
drop table Abc;

大部分 alter table 的操作都是会自动同步到 history 的, 但有些不会啦. 以后真的用的时候才研究.

SQL server temporal table 学习笔记的更多相关文章

  1. sql server自定义函数学习笔记

    sql server中函数分别有:表值函数.标量函数.聚合函数.系统函数.这些函数中除系统函数外其他函数都需要用户进行自定义. 一.表值函数 简单表值函数 创建 create function fu_ ...

  2. SQL Server物化视图学习笔记

    一. 基本知识   摘抄自http://www.cnblogs.com/kissdodog/p/3385161.html SQL Server索引 - 索引(物化)视图 <第九篇> 索引视 ...

  3. 数据库(sql server 2000)—— 学习笔记1

    一.安装 安装程序一般都是四合一的,SQL Server 2000有四个版本:企业版.标准版.个人版.开发版,每个版本的对系统的要求各不相同. SQL Server 2000各版本 对 操作系统的要求 ...

  4. sql server 2016 JSON 学习笔记

    虽然现在win服务器已经几乎不用了,但是网上看到2016开始原生支持json 还是想试试 建立一个表  id int , json varchar(2000) json字段中输入数据 {"r ...

  5. SQL SERVER 常用函数 学习笔记

    1.字符串截取.字符串转数字 --Server.8.30 select SUBSTRING('SqlServer_2008',4,6) as DB, CONVERT(float,SUBSTRING(' ...

  6. 《SQL 反模式》 学习笔记

    第一章 引言 GoF 所著的的<设计模式>,在软件领域引入了"设计模式"(design pattern)的概念. 而后,Andrew Koenig 在 1995 年造了 ...

  7. mysql与sql server参照对比学习mysql

    mysql与sql server参照对比学习mysql 关键词:mysql语法.mysql基础 转自桦仔系列:http://www.cnblogs.com/lyhabc/p/3691555.html ...

  8. SQL Server中Table字典数据的查询SQL示例代码

    SQL Server中Table字典数据的查询SQL示例代码 前言 在数据库系统原理与设计(第3版)教科书中这样写道: 数据库包含4类数据: 1.用户数据 2.元数据 3.索引 4.应用元数据 其中, ...

  9. SQL Server 2008 R2——学习/练习/错误/总结/搜集

    ==================================声明================================== 本文原创,转载在正文中显要的注明作者和出处,并保证文章的完 ...

  10. sql server 存储过程的学习

    存储过程学习笔记 存储过程就是一条或者多条sql语句的集合,为了实现特定任务,而将一些需要多次调用的固定操作语句编写成程序段,这些程序段存储在服务器上,有数据库服务器通过程序来调用.T_SQL:存储过 ...

随机推荐

  1. IP协议学习笔记

    目录 IP地址格式 IP分类 CIDR 和 子网掩码介绍 NAT+公网.私网地址 CIDR 与 VLSM VLSM 子网划分案例 练习 Reference IP的作用类似物理世界中的地址,用于定位机器 ...

  2. TypeScript 学习笔记 — 类型补充void,any, tuple ,enum,nerver, Symbol , BigInt ,unknown(三)

    目录 空值void 及(与Null 和 Undefined的区别) 任意值Any 元组类型 枚举类型 常量枚举 never 类型 1. 函数无法到达终点 2.通常校验逻辑的完整性,可以利用 never ...

  3. [oeasy]python0129_unicode_中文字符序号_十三道大辙_字符编码解码_eval_火星文

    unicode 中文字符分类 回忆上次内容 字符集 从博多码 到 ascii 再到 iso-8859 系列 各自割据   如何把世界上各种字符统进行编码 unicode顺势而生不断进化 不过字符总量超 ...

  4. [oeasy]python0083_十进制数如何存入计算机_八卦纪事_BCD编码_Binary_Coded_Decimal

    编码进化 回忆上次内容 上次 研究了 视频终端的 演化 从VT05 到 VT100 从 黑底绿字 到 RGB 24位真彩色 形成了 VT100选项 从而 将颜色 数字化 了 生活中我们更常用 10个数 ...

  5. Docker 容器开发:虚拟化

    Docker 容器开发:虚拟化 Docker 的核心价值在于虚拟化或者说环境隔离[通过虚拟化技术实现虚拟环境],解决环境配置和部署的依赖问题实现解耦 我对虚拟化的理解源自<Operating S ...

  6. LeetCode102.二叉树的层序遍历

    LeetCode题目链接:https://leetcode.cn/problems/binary-tree-level-order-traversal/submissions/548489149/ 题 ...

  7. 如何在Arch Linux上构建Raspberry Pi虚拟环境

    如何在Linux上构建Raspberry Pi虚拟环境 ​ 下面我们来讲讲如何使用QEMU来仿照树莓派环境.这里首先先分成两大类.第一类是跑比较老的,安全性较低的老树莓派,主要指代的是22年4月份发布 ...

  8. 备份服务器eBackup

    目录 软件包方式安装eBackup备份软件   1.前景提要   2.创建虚拟机   3.安装备份软件.   4.安装 eBackup 补丁   5.配置 eBackup 服务器   6.访问web界 ...

  9. python统计班级学生

    python统计班级学生 如下场景: 假设我有一个学生类和一个班级类,想要实现的功能为:    执行班级人数增加的操作.获得班级的总人数:    学生类继承自班级类,每实例化一个学生,班级人数都能增加 ...

  10. 【VMware VCF】VMware Cloud Foundation Part 06:部署 VI 工作负载域。

    VMware Cloud Foundation 标准架构中,管理域和 VI 工作负载域需要分开部署,管理域是初始构建(Bring-up)中部署的一个工作负载域并且只有一个,管理域专门用于承载管理相关组 ...