数据库_序列索引同义词.pptVIP

  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文档。上传文档
查看更多
数据库_序列索引同义词

第12章 序列索引同义词 Oracle SQLPL/SQL基础教程 目标 本课即将学习 序列 用于自动生成主键值 索引 用于提高表的查询速度 同义词 为数据库对象起别名,简化SQL语句 序列 19-1 序列 是数据库对象, 允许多个用户访问 可以自动生成递增(或递减)的唯一编号序列,减少为表分配主键值编写的代码,节省时间 编号的存储和生成与表无关。因此,同一序列可以用于多个表 序列 19-2 创建语法: CREATE SEQUENCE sequence [INCREMENT BY n] [START WITH n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}]; 序列 19-3 为员工表创建序列,编号从1 开始并以1 递增 员工编号数据类型为 NUMBER(4),所以序列最大值设为10000就够了 序列 19-4 NOCACHE 选项会阻止序列值进入内存,这样可以防止在系统出现故障时预先分配并驻留在内存中的编号丢失 NOCYCLE 选项可阻止在值超过10,000 时重新从1 开始分配编号。如果序列用于生成主键值,则不要使用CYCLE 选项,除非有可靠的机制能保证删除旧行的速度高于添加新行的速度 序列 19-5 如仅需验证是否已创建序列,请查询USER_OBJECTS 数据字典。 若要查看所有信息,请查询USER_SEQUENCES数据字典 SELECT sequence_name, min_value, max_value, increment_by, last_number FROM user_sequences; 如果指定NOCACHE,则以上查询中的last_number列会显示下一个有效的序列号 如果指定CACHE,则last_number列会显示序列中尚未进入内存的下一个有效编号 序列 19-6 NEXTVAL 伪列 用于从指定的序列中提取连续的序列号 必须用序列名来限定NEXTVAL 在引用sequence.NEXTVAL 时,会生成新的序列号,还会将当前的序列号放置在CURRVAL 中 下例在“部门”表中插入了新部门。DEPT_DEPTNO_SEQ 序列用来生成新的部门编号: INSERT INTO dept(deptno, dname, loc) VALUES (dept_deptno_seq.NEXTVAL, Support, ‘jinan’); 序列 19-7 添加新员工的INSERT 语句中可以包含以下代码: INSERT INTO emp (empno,deptno, ...) VALUES (emp_empno_seq.NEXTVAL,dept_deptno_seq .CURRVAL, ...); 注:假设已经创建了EMP_EMPNO_SEQ的序列,用于生成新雇员编号 序列 19-8 CURRVAL 用于查看或使用 序列的当前值,即最后一次调用NEXTVAL 生成的序列值 当前会话中,必须先调用NEXTVAL ,然后才能引用CURRVAL 必须用序列名来限定CURRVAL 不改变序列值 序列 19-9 CREATE SEQUENCE emp_seq; Select emp.currval from dual; ORA-08002: 序列 A_SEQ.CURRVAL 尚未在此会话中定义 Select emp. nextval from dual; -- 返回1 Select emp. nextval from dual; -- 返回2 Select emp.currval from dual; -- 返回2 Select emp.currval from dual; -- 返回2 序列 19-10 可以使用NEXTVAL 和CURRVAL的情形: 非子查询 SELECT 语句的SELECT 列表 INSERT 语句中子查询的SELECT 列表 INSERT 语句的VALUES 子句 UPDATE 语句的SET 子句 序列 19-11 不能使用NEXTVAL 和CURRVAL的情形: 视图的SELECT 列表 带有DISTINCT 关键字的SELECT 语句 带有GROUP BY、HAVING 或ORDER BY 子句的SELECT 语句 SELECT、DELETE 或UPDATE 语句中的子查询 CREATE TABLE 或ALTER TABLE 语句中的DEFAULT 表达式 序列 19-12 Cache/NOCache 选项 利用缓存可以更快地生成访问序列值 首次引用序列的NEXTVAL时,在缓存池中填满序列值,并

文档评论(0)

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

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

1亿VIP精品文档

相关文档