SQL Server2012中的SequenceNumber尝试

本文深入解析了SQLServer2012中SequenceNumber特性的使用方法,包括其基本概念、用法、注意事项及优势。SequenceNumber允许在多表或多列之间共享序列号,简化了流水号管理过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

    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。

    1

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

 

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

    2

    图2.sys.sequences视图

 

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

    3

    图3.在单表中插入序列

 

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

    4

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

   

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

    5

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

 

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

    6

    图6.重置Sequence的值

 

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

    7

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

 

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

    8

    图8.为Sequence设置Cache选项

 

 

总结

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

 

参考资料:Sequence Numbers

                CREATE SEQUENCE (Transact-SQL)

### 如何配置和使用 SQL Server 审计功能 #### 创建审计对象 为了启用SQL Server的审计功能,需要创建一个审计对象。这可以通过图形界面完成,也可以通过T-SQL语句来实现。当采用后者时,可以利用`CREATE SERVER AUDIT`命令[^1]。 ```sql USE master; GO CREATE SERVER AUDIT [MyAudit] TO FILE (FILEPATH = 'C:\Audits\') WITH (ON_FAILURE = CONTINUE); ALTER SERVER AUDIT [MyAudit] WITH (STATE = ON); GO ``` 上述代码片段展示了如何定义一个新的服务器级别的审计实例,并将其日志文件保存到指定路径下;同时设置了遇到错误时不中断操作继续运行,并启动了此审计实例。 #### 关联审计规范 接着要建立审计规格说明(Audit Specification),它决定了哪些类型的事件会被捕捉并记录下来。对于数据库层面的操作监控,则需构建数据库级别的审计规格(`DATABASE_AUDIT_SPECIFICATION`);而针对整个实例的行为审查则应设立服务器级别的审计规格(`SERVER_AUDIT_SPECIFICATION`)。这里给出设置服务器级别审计规格的例子: ```sql USE master; GO CREATE SERVER AUDIT SPECIFICATION [MyServerAuditSpec] FOR SERVER AUDIT [MyAudit] ADD (SCHEMA_OBJECT_CHANGE_GROUP), ADD (SUCCESSFUL_LOGIN_GROUP) WITH (STATE = ON); GO ``` 这段脚本指定了两个动作组——模式对象变更以及成功的登录尝试作为被监视的目标类别[^2]。 #### 查看与管理审计数据 一旦完成了前面几步之后,所有的符合条件的动作都会按照设定的方式被捕获至相应的存储位置中去。管理员能够借助系统视图如`sys.fn_get_audit_file()`函数读取这些信息以便进一步处理或报告生成[^3]。 ```sql SELECT event_time, sequence_number, action_id, server_principal_name, database_name, schema_name, object_name, statement FROM sys.fn_get_audit_file('C:\Audits\', DEFAULT, DEFAULT); ``` 以上查询语句用于检索特定目录下的所有审计记录条目,返回的结果集包含了时间戳、序列号、行为ID以及其他有关上下文的信息字段。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值