您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

Oracle DB序列_MySQL

2024/2/19 15:59:05发布17次查看
bitscn.com
oracle db序列
序列是一个用于创建整数值的数据库对象。可以创建序列,然后再用其生成编号。
序列具有如下特点:
• 可以自动生成唯一编号
• 是一个可共享的对象
• 可用于创建主键值
• 替换应用程序代码
• 如果将序列高速缓存到内存中,则访问序列值的效率会有所提高
序列是用户创建的数据库对象,可由多个用户共享来生成整数。
可以通过定义一个序列来生成唯一值,或者回收编号后重新使用相同的编号。
序列的常见用途是创建主键值,每行的主键值必须是唯一的。序列由内部oracle  例行程序按递增(或递减)方式生成。由于可以减少编写生成序列的例行程序所需的应用程序代码量,因此使用该对象可以节省一些时间。
序列号的存储和生成与表无关。因此,同一序列可以用于多个表。
create sequence 语句:语法
定义一个可以自动生成序号的序列:
create sequence sequence[increment by n][start with n][{maxvalue n | nomaxvalue}][{minvalue n | nominvalue}][{cycle | nocycle}][{cache n | nocache}];
通过使用create sequence语句可以自动生成序号。
在该语法中:
sequence:是序列生成器的名称
increment by n: 指定序列号之间的间隔,其中n 是一个整数(如果省略此子句,则序列按1 递增)
start with n: 指定要生成的第一个序列号(如果省略此子句,则序列从1 开始)
maxvalue n: 指定序列可以生成的最大值
nomaxvalue 指定10^27 作为递增序列的最大值,而-1 作为递减序列的最大值(这是默认选项)
minvalue n :指定最小的序列值
nominvalue :指定1 作为递增序列的最小值,而-(10^26) 作为递减序列的最小值(这是默认选项)
创建序列
• 创建一个名为dept_deptid_seq的序列,将其用作departments 表的主键。
• 不使用cycle选项。
sys@test0924> create sequence dept_deptid_seq 2 increment by 10 3 start with 120 4 maxvalue 9999 5 nocache 6 nocycle 7 ;sequence created.
cycle | nocycle :指定在达到最大值或最小值之后,序列是否继续生成值(nocycle是默认选项)
cache n | nocache :指定oracle server 预先分配并保留在内存中的值的数量(默认情况下,oracle server 会高速缓存20 个值)
示例中创建了一个名为dept_deptid_seq的序列,用作departments 表的department_id 列。该序列从120 开始,不允许高速缓存,也不进行循环。
请勿在序列用于生成主键值时使用cycle选项,除非有一个可靠的机制与序列循环相比可以更快地清除旧行。
注:序列与表没有关系。通常,应按序列的预期用途来命名序列。但是,序列可以在任何地方使用,而与其名称无关。
nextval和currval伪列
• nextval会返回下一个可用的序列值。每次被引用时nextval都会返回一个唯一值,即使对于不同用户也是如此。
• currval会获得当前序列值。
• 只有对序列发出nextval之后,currval才能包含值。
在创建一个序列之后,该序列会生成可以在表中使用的序号。通过使用nextval和currval伪列可以引用序列值。
nextval伪列用于从指定的序列中提取连续的序列号。必须用序列名来限定nextval。
在引用sequence .nextval 时,就会生成新的序列号,还会将当前的序列号放在currval中。
currval伪列用于引用当前用户刚刚生成的序列号。但是,必须先用nextval在当前用户的会话中生成一个序列号,然后才能引用currval。必须用序列名来限定currval。
在引用sequence .currval 时,会显示返回给用户进程的最后一个值。
使用nextval和currval的规则
可以在下列上下文中使用nextval和currval:
• 不是子查询一部分的select 语句的select 列表
• insert 语句中子查询的select 列表
• insert 语句的values 子句
• update 语句的set 子句
不能在下列上下文中使用nextval和currval:
• 视图的select 列表
• 带有distinct 关键字的select 语句
• 带有group by 、having 或order by 子句的select 语句
• select 、delete 或update 语句中的子查询
• create table或alter table 语句中的default表达式
使用序列
• 在位置id 2500 中插入一个名为“support”的新部门:
sys@test0924> insert into hr.departments(department_id, department_name,location_id) 2 values (dept_deptid_seq.nextval, 'support', 2500);1 row created.
它使用dept_deptid_seq序列生成280的新部门编号。
• 使用sequence_name.currval查看dept_deptid_seq序列的当前值:
sys@test0924> select dept_deptid_seq.currval from dual; currval---------- 280
假定现在要聘用某些雇员作为新部门的工作人员。在要对所有新雇员执行的insert语句中可以包含以下代码:
insert into employees (employee_id, department_id, ...)values (employees_seq.nextval, dept_deptid_seq .currval, ...);
注:上面的示例假设已经创建一个名为 employee_seq的序列来生成新雇员编号。
高速缓存序列值
• 将序列值高速缓存在内存中,这样可以更快地对这些值进行访问。
• 在发生以下情况时,序列值会出现间断:
– 发生回退
– 系统崩溃
– 序列已用于其它表中
可以将序列高速缓存在内存中,以便于更快地对这些值进行访问。当首次引用序列时,序列值会被填充到高速缓存中。因此会从高速缓存序列中检索每次请求的下一个新序列值。用完最后一个序列值之后,就会在下一次请求序列时将序列的另一个高速缓存拖入到内存中。
序列中的间断
虽然序列生成器会发出没有间断的序号,但是此操作的发生与提交或回退有关。因此,如果你回退一条包含序列的语句,则会丢失相应的序号。
另一个可能导致序列出现间断的事件是系统崩溃。如果序列值已高速缓存在内存中,那么在系统崩溃时就会丢失一些值。
因为序列不直接与表相关联,所以同一序列可用于多个表。但是,如果同一序列用于多个表,则每个表的序号可能会有间断。
修改序列
更改增量值、最大值、最小值、循环选项或高速缓存选项:
sys@test0924> alter sequence dept_deptid_seq 2 increment by 20 3 maxvalue 999999 4 nocache 5 nocycle;sequence altered.
如果序列达到maxvalue 限制,则序列不会再分配额外的值,此时你会收到一条错误消息,指明序列超出了maxvalue 。要继续使用该序列,可以使用alter sequence语句修改该序列。
语法
alter sequence sequence[increment by n ][{maxvalue n | nomaxvalue}][{minvalue n | nominvalue}][{cycle | nocycle}][{cache n | nocache}];
在此语法中,sequence 是序列生成器的名称。
修改序列的准则
• 你必须是序列的所有者或拥有序列的alter权限。
• 修改只会影响以后生成的序列号。
• 如果要从另一编号处重新开始,则必须删除原有序列后重新创建。
• 在修改过程中会执行一些验证操作。
• 要删除序列,请使用drop 语句:
sys@test0924> drop sequence dept_deptid_seq;sequence dropped.
• 要修改一个序列,你必须是此序列的所有者或拥有序列的alter权限。要删除一个序列,你必须是此序列的所有者或拥有此序列的drop any sequence权限。
• alter sequence 语句只会影响以后生成的序列号。
• 使用alter sequence 语句不能更改start with选项。如果要从另一编号处重新开始,则必须删除原有序列后重新创建。
• 在修改过程中会执行一些验证操作。例如,不能强制实施一个小于当前序列号的新maxvalue 。
alter sequence dept_deptid_seqincrement by 20maxvalue 90nocachenocycle;• 错误:sys@test0924> alter sequence dept_deptid_seq 2 increment by 20 3 maxvalue 99 4 nocache 5 nocycle;alter sequence dept_deptid_seq*error at line 1:ora-04009: maxvalue cannot be made to be less than the current value
bitscn.com
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product