NEXTVAL()的用法.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NEXTVAL()的用法

SQL:NEXTVAL()的用法 CREATE SEQUENCENameCREATE SEQUENCE?--?创建一个新的序列发生器SynopsisCREATE [ TEMPORARY | TEMP ] SEQUENCE name [ INCREMENT [ BY ] increment ] [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ] [ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE ]描述 CREATE SEQUENCE?将向当前数据库里增加一个新的序列号生成器。 包括创建和初始化一个新的名为?name的单行表。生成器将为使用此命令的用户所有。 如果给出了一个模式名,那么该序列是在指定模式中创建的。 否则它会在当前模式中创建临时序列存在于一个特殊的模式中,因此如果创建一个临时序列的时候, 不能给出模式名。 序列名必需和同一模式中的其他序列,表,索引,或者视图不同。 在序列创建后,你可以使用函数?nextval,?currval,和?nextval?操作序列。这些函数在? HYPERLINK /database/postgresql_8.0_CN/functions-sequence.html Section 9.12?中有详细文档。 尽管你不能直接更新一个序列,但你可以使用象 SELECT * FROM name; 检查一个序列的参数和当前状态。特别是序列的?last_value?字段显示了任意后端进程分配的最后的数值。 (当然,这些值在被打印出来的时候可能已经过时了 --- 如果其它进程正积极地使用?nextval。) 参数 TEMPORARY?或?TEMP 如果声明了这个修饰词,那么该序列对象只为这个会话创建, 并且在会话结束的时候自动删除。在临时序列存在的时候, 同名永久序列是不可见的(在同一会话里),除非它们是用模式修饰的名字引用的。 name 将要创建的序列号名(可以用模式修饰)。 increment 可选子句?INCREMENT BY?increment?要创建一个新的值,应该向当前序列值上增加什么。一个正数将生成一个递增的序列, 一个负数将生成一个递减的序列。缺省值是一(1)。 minvalue NO MINVALUE 可选的子句?MINVALUE?minvalue?决定一个序列可生成的最小值。 如果没有声明这个子句或者声明了?NO MINVALUE,那么就使用缺省。 缺省分别是递增序列为 1 递减为 -263-1。 maxvalue NO MAXVALUE 使用可选子句?MAXVALUE?maxvalue?决定序列的最大值。 如果没有声明这个子句或者声明了?NO MAXVALUE,那么就使用缺省。 缺省的分别是递增为 -263-1,递减为 -1。 start 可选的?START WITH?start?子句?使序列可以从任意位置开始。缺省初始值是递增序列为?minvalue?递减序列为?maxvalue. cache CACHE?cache?选项使序列号预分配并且为快速访问存储在内存里面。 最小值(也是缺省值)是1(一次只能生成一个值, 也就是说没有缓存)这也是缺省。 CYCLE NO CYCLE 可选的CYCLE关键字可用于使序列到达?最大值(maxvalue)?或?最小值(minvalue)?时可复位并继续下去。如果达到极限,生成的下一个数据将分别是?最小值(minvalue)?或?最大值(maxvalue)。 如果声明了可选的关键字?NO CYCLE, 那么在序列达到其最大值之后任何对?nextval?的调用都强返回一个错误。 如果既没有声明?CYCLE?也没有声明?NO CYCLE, 那么?NO CYCLE?是缺省。 注意 使用?DROP SEQUENCE?语句来删除序列。 序列是基于?bigint?运算的,因此其范围不能超过八字节的整数范围(-9223372036854775808 到 9223372036854775807)。 在一些老一点的平台上可能没有对八字节整数的编译器支持, 这种情况下序列使用普通的?integer?运算(范围是 -2147483648 到 +2147483647)。 如果?cache?设置大于一, 并且这个序列对象将被用于并发多会话的场合,那么可能会有不可预料的结果发生。 每个会话在一次访问序列对象的过程中将分配并缓存随后的序列值,并且相应增加序列对象的?last_value。 这样,同一个事务中的随后的?cache-1 次?nextval?将只是返回预先分配的数值,而不用动序列对象。

文档评论(0)

hhuiws1482 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:5024214302000003

1亿VIP精品文档

相关文档