搜索
首页数据库mysql教程Oracle DB序列_MySQL

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
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
将用户添加到MySQL:完整的教程将用户添加到MySQL:完整的教程May 12, 2025 am 12:14 AM

掌握添加MySQL用户的方法对于数据库管理员和开发者至关重要,因为它确保数据库的安全性和访问控制。1)使用CREATEUSER命令创建新用户,2)通过GRANT命令分配权限,3)使用FLUSHPRIVILEGES确保权限生效,4)定期审计和清理用户账户以维护性能和安全。

掌握mySQL字符串数据类型:varchar vs.文本与char掌握mySQL字符串数据类型:varchar vs.文本与charMay 12, 2025 am 12:12 AM

chosecharforfixed-lengthdata,varcharforvariable-lengthdata,andtextforlargetextfield.1)chariseffity forconsistent-lengthdatalikecodes.2)varcharsuitsvariable-lengthdatalikenames,ballancingflexibilitibility andperformance.3)

MySQL:字符串数据类型和索引:最佳实践MySQL:字符串数据类型和索引:最佳实践May 12, 2025 am 12:11 AM

在MySQL中处理字符串数据类型和索引的最佳实践包括:1)选择合适的字符串类型,如CHAR用于固定长度,VARCHAR用于可变长度,TEXT用于大文本;2)谨慎索引,避免过度索引,针对常用查询创建索引;3)使用前缀索引和全文索引优化长字符串搜索;4)定期监控和优化索引,保持索引小巧高效。通过这些方法,可以在读取和写入性能之间取得平衡,提升数据库效率。

mysql:如何远程添加用户mysql:如何远程添加用户May 12, 2025 am 12:10 AM

ToaddauserremotelytoMySQL,followthesesteps:1)ConnecttoMySQLasroot,2)Createanewuserwithremoteaccess,3)Grantnecessaryprivileges,and4)Flushprivileges.BecautiousofsecurityrisksbylimitingprivilegesandaccesstospecificIPs,ensuringstrongpasswords,andmonitori

MySQL字符串数据类型的最终指南:有效的数据存储MySQL字符串数据类型的最终指南:有效的数据存储May 12, 2025 am 12:05 AM

tostorestringsefliceflicyInmySql,ChooSetherightDataTypeBasedyOrneOrneEds:1)USEcharforFixed-LengthStstringStringStringSlikeCountryCodes.2)UseVarcharforvariable-lengtthslikenames.3)USETEXTCONTENT.3)

mysql blob vs.文本:为大对象选择正确的数据类型mysql blob vs.文本:为大对象选择正确的数据类型May 11, 2025 am 12:13 AM

选择MySQL的BLOB和TEXT数据类型时,BLOB适合存储二进制数据,TEXT适合存储文本数据。1)BLOB适用于图片、音频等二进制数据,2)TEXT适用于文章、评论等文本数据,选择时需考虑数据性质和性能优化。

MySQL:我应该将root用户用于产品吗?MySQL:我应该将root用户用于产品吗?May 11, 2025 am 12:11 AM

No,youshouldnotusetherootuserinMySQLforyourproduct.Instead,createspecificuserswithlimitedprivilegestoenhancesecurityandperformance:1)Createanewuserwithastrongpassword,2)Grantonlynecessarypermissionstothisuser,3)Regularlyreviewandupdateuserpermissions

MySQL字符串数据类型说明了:选择适合您数据的合适类型MySQL字符串数据类型说明了:选择适合您数据的合适类型May 11, 2025 am 12:10 AM

mySqlStringDatatatPessHouldBechoseBeadeDataCharacteristicsAndUsecases:1)USECHARFORFIXED LENGTHSTRINGSTRINGSLIKECOUNTRYCODES.2)USEDES.2)usevarcharforvariable-lengtthstringstringstringstringstringstringstringslikenames.3)usebinaryorvarrinaryorvarinarydatalbonydatalgebgeenfopical.4)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中