17站长网

17站长网 首页 数据库 oracle 查看内容

oracle序列的理念是什么

2023-3-21 14:43| 查看: 1410 |来源: 互联网

今天小编给大家分享一下oracle序列的概念是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望 ...

今天小编给大家分享一下oracle序列的概念是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

 

  在oracle中,序列是用于产生一系列唯一数字的数据库对象;序列也就是一个序列号生成器,可以为表中的行自动生成序列号,主要的用途是生成主键的值,并且定义序列的用户必须具有CREATE SEQUENCE权限。本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

 

  序列: Sequence 是oracle提供的用于产生一系列唯一数字的数据库对象。由于oracle中没有设置自增列的方法,所以我们在oracle数据库中主要用序列来实现主键自增的功能。

 

  在Oracle数据库中,序列(sequence)其实就是一个序列号生成器,它可以为表中的行自动生成序列号,主要的用途是生成表的主键值。相当于SQL Server和MySQL中的自增字段。在SQL Server中可以在定义主键时使用identity关键字定义,在MySQL中可以在定义主键时使用increment关键字定义。在Oracle数据库中要想使用自增字段,必须先定义一个序列(sequence)对象,然后在插入数据时使用【序列对象名.nextval】在主键中插入自增数据。

 

  要定义序列,则定义序列的用户必须具有CREATE SEQUENCE权限。在Oracle数据库中,定义序列的语法如下:

 

  CREATE SEQUENCE 序列名

 

  [START WITH n]

 

  [INCREMENT BY n]

 

  [MAXVALUE n|NOMAXVALUE]

 

  [MINVALUE n|NOMINVALUE]

 

  [CACHE n|NOCACHE]

 

  [CYCLE|NOCYCLE]

 

  参数说明:

 

  (1)INCREMENT BY:定义序列的步长,n如果为正值,表示序列是一个递增序列;n如果为负值,表示序列是一个递减序列;如果省略,则默认值为1。

 

  (2)START WITH:定义序列的起始值,如果省略,则默认值为1。MAXVALUE:定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。

 

  (3)MINVALUE:定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是-10的26次方;对于递增序列,最小值是1。

 

  (4)CYCLE|NOCYCLE:表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。CACHE:定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。


  扩展知识:

 

  修改序列

 

  格式:

 

  ALTER SEQUENCE name [INCREMENT BY n]

 

      [MINVALUE n | NO MINVALUE]

 

      [MAXVALUE n | NO MAXVALUE ]

 

      [MINVALUE n | NO MINVALUE ]

 

      [CACHE n ]

 

      [CYCLE | NO CYCLE]

 

  以上就是“oracle序列的概念是什么”这篇文章的所有内容,感谢各位的阅读!

本文最后更新于 2023-3-21 14:43,某些文章具有时效性,若有错误或已失效,请在网站留言或联系站长:17tui@17tui.com
·END·
站长网微信号:w17tui,关注站长、创业、关注互联网人 - 互联网创业者营销服务中心

免责声明:本站部分文章和图片均来自用户投稿和网络收集,旨在传播知识,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系我们及时修正或删除。谢谢!

17站长网微信二维码

始终以前瞻性的眼光聚焦站长、创业、互联网等领域,为您提供最新最全的互联网资讯,帮助站长转型升级,为互联网创业者提供更加优质的创业信息和品牌营销服务,与站长一起进步!让互联网创业者不再孤独!

扫一扫,关注站长网微信

大家都在看

热门排行

最近更新

返回顶部