SQLServer中Sequence对象用法


本文整理自网络,侵删。

一、Sequence简介

Sequence对象对于Oracle用户来说是最熟悉不过的数据库对象了, 在SQL SERVER2012终于也可以看到这个对象了。Sequence是SQL Server2012推出的一个新特性。这个特性允许数据库级别的序列号在多表或多列之间共享。

二、Sequence基本概念

Oracle中有Sequence的功能,SQL server类似的功能要使用identity列实现,但是identity列有很大的局限性。微软终于在2012中添加了Sequence对象。与以往identity列不同的是:Sequence是一个  与架构绑定的数据库级别的对象,而不是与具体的表的具体列所绑定。这就意味着Sequence带来多表之间共享序列号的便利之外,还会带来如下不利影响:

  • 1、与identity列不同的是,Sequence插入表中的序列号可以被Update,除非通过触发器来进行保护
  • 2、与identity列不同,Sequence有肯能插入重复值(Sequence可以设置循环,对于循环的Sequence来说会有重复值)
  • 3、Sequence仅仅负责产生序列号,并不负责控制如何使用序列号,因此当生成一个序列号被Rollback之后,Sequence会继续生成下一个序列号,从而在序列号之间产生间隙

三、Sequence的用法

MSDN上对创建Sequence的语法如下:

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 } ]  
    [ ; ]

 参数:

sequence_name
指定数据库中已知序列的唯一名称。类型是sysname。

[built_in_integer_type | user-defined_integer_type 
可以将序列定义为任何整数类型。允许以下类型。

  • tinyint - 范围0到255

  • smallint - 范围-32,768至32,767

  • int - 范围-2,147,483,648至2,147,483,647

  • bigint - 范围-9,223,372,036,854,775,808至9,223,372,036,854,775,807

  • 十进制和数字为0的规模。

  • 基于允许类型之一的任何用户定义的数据类型(别名类型)。

    如果没有提供数据类型,则使用bigint数据类型作为默认值。

    START WITH <constant> 
    序列对象返回的第一个值。START值必须小于一个值,或等于最大且大于或等于所述序列对象的最小值。新的序列对象的默认起始值??是升序序列对象的最小值和降序序列对象的最大值。

    INCREMENT BY <constant> 
    用于每次调用NEXT VALUE FOR函数的序列对象的值递增(或减少为负)的值。如果增量是负值,则序列对象是递减的; 否则,它是升序。增量不能为0.新序列对象的默认增量为1。

    [MINVALUE <constant> | NO MINVALUE ] 
    指定序列对象的边界。新序列对象的默认最小值是序列对象的数据类型的最小值。对于tinyint数据类型为零,所有其他数据类型为负数。

    [MAXVALUE <constant> | NO MAXVALUE
    指定序列对象的边界。新序列对象的默认最大值是序列对象的数据类型的最大值。

    [CYCLE | NO CYCLE ] 
    指定序列对象是否应从最小值(或降序序列对象的最大值)重新启动的属性,或者在超过最小值或最大值时引发异常。新序列对象的默认循环选项为NO CYCLE。

    请注意,循环从最小值或最大值重新启动,而不是从起始值开始。

    [ CACHE [<constant>] | NO CACHE] 
    通过最小化生成序列号所需的磁盘IO数量,提高使用序列对象的应用程序的性能。默认为CACHE。

    阅读剩余部分

    相关阅读 >>

    一小时迅速入门mybatis之prepared statement与符号的使用

    oracle plsql中异常高级特性示例解析

    navicat如何连接sqlserver数据库

    sql语句如何截取某字段的一部分

    sql中删除表数据和删除表结构有什么不同

    sqlserver 高性能分页实现分析

    详解navicat简单使用方法

    sql中like的用法

    sql server sql高级查询语句小结

    sql的临时表使用小结

    更多相关阅读请进入《sql》频道 >>


    数据库系统概念 第6版
    书籍

    数据库系统概念 第6版

    机械工业出版社

    本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...