SQL Server序列SEQUENCE用法介绍
时间:2024-03-11 15:08作者:下载吧人气:20
一、概述
SQL SERVER2012 之前版本,一般采用GUID或者IDENTITY来作为标示符。在2012中,微软终于增加了 SEQUENCE 对象,功能和性能都有了很大的提高。
序列是一种用户定义的架构绑定对象,它根据创建该序列时采用的规范生成一组数值。 这组数值以定义的间隔按升序或降序生成,并且可根据要求循环(重复)。
- 序列不与表相关联,这一点与标识列不同。
- 应用程序将引用某一序列对象以便接收其下一个值。
- 序列是通过使用 CREATE SEQUENCE 语句独立于表来创建的。 其选项使您可以控制增量、最大值和最小值、起始点、自动重新开始功能和缓存以便改进性能。
- 与在插入行时生成的标识列值不同,应用程序可以通过调用 NEXT VALUE FOR 函数在插入行之前获取下一序列号。 在调用 NEXT VALUE FOR 时分配该序列号,即使在该序列号永远也不插入某个表中时也是如此。 此 NEXT VALUE FOR 函数可用作表定义中某个列的默认值。
- 使用 sp_sequence_get_range 可一次获取某个范围的多个序列号。
- 序列可定义为任何整数数据类型。 如tinyint, smallint, int, bigint, decimal 或是小数精度为0的数值类型。如果未指定数据类型,则序列将默认为
bigint
。
序列的限制(limitation)有二个
- 序列不支持事务,即使事务中进行了回滚(rollback)操作,序列仍然返回下一个元素。
- 序列不支持SQL Server 复制(replication),序列不会复制到订阅的SQL Server实例中。如果一个表的默认值依赖一个序列,而序列又是不可复制的,这会导致订阅的SQL Server出现脚本错误。
选择使用序列的情况:
在以下情况下将使用序列,而非标识列:
- 应用程序要求在插入到表中之前有一个数值。
- 应用程序要求在多个表之间或者某个表内的多个列之间共享单个数值系列。
- 在达到指定的数值时,应用程序必须重新开始该数值系列。 例如,在分配值 1 到 10 后,应用程序再次开始分配值 1 到 10。
- 应用程序要求序列值按其他字段排序。 NEXT VALUE FOR 函数可以将 OVER 子句应用于该函数调用。 OVER 子句确保返回的值按照 OVER 子句的 ORDER BY 子句的顺序生成。
- 应用程序要求同时分配多个数值。 例如,应用程序需要保留五个序号。 如果正在同时向其他进程发出数值,则请求标识值可能会导致在系列中出现间断。 调用 sp_sequence_get_range 可以一次检索该序列中的若干数值。
- 您需要更改序列的规范,例如增量值。
二、创建序列:CREATE SEQUENCE
我们可以在SSMS中创建也可以使用SQL SERVER脚本创建序列对象:


1、使用默认值创建序列:若要创建从 -2,147,483,648 到 2,147,483,647 且增量为 1 的整数序列号。
CREATE SEQUENCE Schema.SequenceName
AS int
INCREMENT BY 1 ;
标签MSSQL,SQLServer,技术文档,数据库,SQLSERVER
网友评论