欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQL Server新特性SequenceNumber用法介绍

程序员文章站 2024-03-26 14:52:05
简介sequencenumber是sql server2012推出的一个新特性。这个特性允许数据库级别的序列号在多表或多列之间共享。对于某些场景会非常有用,比如,你需要在多个表之间公用一个流水号。以往...

简介

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所示。

代码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选项

总结

本文讲述了sequencenumber的简单用法。sequence是一个比较方便的功能,如果使用妥当,将会大大减少开发工作和提升性能。

参考资料:

sequence numbers

create sequence (transact-sql)

到此这篇关于sql server新特性sequencenumber用法的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持。