SQL Server新特性SequenceNumber用法介绍

作者:CareySon 时间:2024-01-15 02:38:34 

简介

SequenceNumber是SQL Server2012推出的一个新特性。这个特性允许数据库级别的序列号在多表或多列之间共享。对于某些场景会非常有用,比如,你需要在多个表之间公用一个流水号。以往的做法是额外建立一个表,然后存储流水号。而新插入的流水号需要两个步骤:

  • 1.查询表中流水号的最大值

  • 2.插入新值(最大值+1)

现在,利用SQL Server2012中的Sequence.这类操作将会变得非常容易。

SequenceNumber的基本概念

SequenceNumber的概念并不是一个新概念,Oracle早就已经实现了(http://docs.oracle.com/cd/B19306_01/server.102/b14200/statements_6015.htm)。与以往的Identity列不同的是。SequenceNumber是一个与构架绑定的数据库级别的对象,而不是与具体的表的具体列所绑定。这意味着SequenceNumber带来多表之间共享序列号的遍历之外,还会带来如下不利影响:

  • 与Identity列不同的是,Sequence插入表中的序列号可以被Update,除非通过触发器来进行保护

  • 与Identity列不同,Sequence有可能插入重复值(对于循环SequenceNumber来说)

  • Sequence仅仅负责产生序列号,并不负责控制如何使用序列号,因此当生成一个序列号被Rollback之后,Sequence会继续生成下一个号,从而在序列号之间产生间隙。

SequenceNumber的用法

SequenceNumber在MSDN中定义的原型如代码1所示。

CREATE SEQUENCE [schema_name . ] sequence_name
   [ AS [ built_in_integer_type | user-defined_integer_type ] ]
   [ START WITH <constant> ]
   [ INCREMENT BY <constant> ]
   [ { MINVALUE [ <constant> ] } | { NO MINVALUE } ]
   [ { MAXVALUE [ <constant> ] } | { NO MAXVALUE } ]
   [ CYCLE | { NO CYCLE } ]
   [ { CACHE [ <constant> ] } | { NO CACHE } ]
   [ ; ]

代码1.Sequence的创建原型

由代码1看以看到,参数相对比较简单。从指定数据类型(INT兼容)到开始计数点,步长,最大值和最小值,是否循环和是否缓存几个参数来设置Sequence。

下面图1创建了一个简单的Sequence。

SQL Server新特性SequenceNumber用法介绍

图1.创建一个简单的Sequence并进行使用

此时,我们可以通过SQL Server 2012新增的视图sys.sequences来看到刚才创建成功的Sequence,如图2所示.

SQL Server新特性SequenceNumber用法介绍

图2.sys.sequences视图

当然我们可以这个序列按照顺序插入表,如图3所示。

SQL Server新特性SequenceNumber用法介绍

图3.在单表中插入序列

而SequenceNumber最重要的功能是在多表间共享序列号,如图4所示。

SQL Server新特性SequenceNumber用法介绍

图4.多表之间利用Sequence共享序列号

前面图2可以看到,如果我们不指定Sequence的上限和下限,则默认使用所指定数据类型的最大值和最小值作为上限和下限(如图2INT类型的的上下限).当达到上线后,可以指定循环来让Sequence达到上限后从指定的开始值重新开始循环。如图5所示。

SQL Server新特性SequenceNumber用法介绍

图5.Sequence设置上限下限和循环

还可以通过修改Sequence将其初始值指定为一个特定值,如图6所示。

SQL Server新特性SequenceNumber用法介绍

图6.重置Sequence的值

Sequence一个需要注意的情况是Sequence只负责生成序列号,而不管序列号如何使用,如果事务不成功或回滚,SequenceNumber仍然会继续向后生成序列号,如图7所示。

SQL Server新特性SequenceNumber用法介绍

图7.Sequence仅仅负责生成序列号

我们还可以为Sequence指定缓存选项,使得减少IO,比如,我们指定Cache选项为4,则当前的Sequence由1增长过4后,SQL Server会再分配4个空间变为从5到8,当分配到9时,SQL Server继续这以循环,如果不指定Cache值,则值由SQL Server进行分配。一个简单的例子如图8所示。

SQL Server新特性SequenceNumber用法介绍

图8.为Sequence设置Cache选项

来源:https://www.cnblogs.com/CareySon/archive/2012/03/12/2391581.html

标签:SQL,Server,SequenceNumber,用法
0
投稿

猜你喜欢

  • 通过javascript进行UTF-8编码的实现方法

    2024-04-16 10:39:49
  • 详解Visual Studio使用Git忽略不想上传到远程仓库的文件

    2023-10-13 06:42:21
  • Python通过递归获取目录下指定文件代码实例

    2021-02-24 15:08:51
  • mysql通过查看跟踪日志跟踪执行的sql语句

    2024-01-28 00:56:10
  • PYTHON基础-时间日期处理小结

    2023-04-23 02:02:59
  • ASP正则表达式验证域名是否合法

    2010-01-02 20:44:00
  • 鼠标双击滚动屏幕单击停止代码

    2008-02-21 11:44:00
  • python实现的简单文本类游戏实例

    2022-10-22 02:32:51
  • 设计稿标注首屏线的确定始末

    2011-03-30 12:36:00
  • Python的Twisted框架中使用Deferred对象来管理回调函数

    2021-01-04 09:01:23
  • mysql数据库忘记管理员密码的解决方法

    2024-01-24 10:56:55
  • Python使用matplotlib绘制三维图形示例

    2022-09-14 10:53:14
  • 浅谈innodb_autoinc_lock_mode的表现形式和选值参考方法

    2024-01-12 17:22:55
  • Cpython解释器中的GIL全局解释器锁

    2021-08-29 22:06:43
  • SQL Server 总结复习 (二)

    2012-10-07 10:35:00
  • 使用python的pandas为你的股票绘制趋势图

    2023-12-29 19:48:46
  • SQL Server高级内容之子查询和表链接概述及使用

    2024-01-24 22:34:27
  • Node.js模块全局安装路径配置方法

    2024-05-13 09:28:11
  • python脚本调用iftop 统计业务应用流量的思路详解

    2022-02-07 02:37:12
  • mysql 复制表结构和数据实例代码

    2024-01-18 00:00:45
  • asp之家 网络编程 m.aspxhome.com