下面图1创建了一个简单的Sequence。
图1.创建一个简单的Sequence并进行使用此时,我们可以通过SQL Server 2012新增的视图sys.sequences来看到刚才创建成功的Sequence,如图2所示.
图2.sys.sequences视图当然我们可以这个序列按照顺序插入表,如图3所示。
图3.在单表中插入序列而SequenceNumber最重要的功能是在多表间共享序列号,如图4所示。
图4.多表之间利用Sequence共享序列号前面图2可以看到,如果我们不指定Sequence的上限和下限,则默认使用所指定数据类型的最大值和最小值作为上限和下限(如图2INT类型的的上下限).当达到上线后,可以指定循环来让Sequence达到上限后从指定的开始值重新开始循环。如图5所示。
图5.Sequence设置上限下限和循环还可以通过修改Sequence将其初始值指定为一个特定值,如图6所示。
图6.重置Sequence的值Sequence一个需要注意的情况是Sequence只负责生成序列号,而不管序列号如何使用,如果事务不成功或回滚,SequenceNumber仍然会继续向后生成序列号,如图7所示。
图7.Sequence仅仅负责生成序列号我们还可以为Sequence指定缓存选项,使得减少IO,比如,我们指定Cache选项为4,则当前的Sequence由1增长过4后,SQL Server会再分配4个空间变为从5到8,当分配到9时,SQL Server继续这以循环,如果不指定Cache值,则值由SQL Server进行分配。一个简单的例子如图8所示。
图8.为Sequence设置Cache选项总结
本文讲述了SequenceNumber的简单用法。Sequence是一个比较方便的功能,如果使用妥当,将会大大减少开发工作和提升性能。
参考资料:
Sequence Numbers
CREATE SEQUENCE (Transact-SQL)
到此这篇关于SQL Server新特性SequenceNumber用法的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持。