- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第4章序列同义词
其它数据库对象 目标 通过本章学习,您将可以: 创建, 维护, 和使用序列 创建和维护索引 创建私有和公有同义词 常见的数据库对象 什么是序列? 在很多的数据库系统中存在一个自动增长的列(如账簿上的流水号,论坛上的帖子ID等到),如果现在想在Oracle中完成自动增长的功能,则只能依靠序列完成,所有的自动增长操作,不需要用户手工完成处理。 序列是oracle专有的对象,它用来产生一个自动递增的数列。 什么是序列? 序列: 序列是多个用户能够以此产生唯一整数的数据库对象,可以用它来自动产生主键值,当然不必是只包含序列的值。使用序列时,不保证将生成一系列连续的值。 自动提供唯一的数值 共享对象 主要用于提供主键值 代替应用代码 将序列值装入内存可以提高访问效率 CREATE SEQUENCE 语句 定义序列: INCREMENT BY: 指定序列号之间的间隔,该值可为正的或负的整数,但不可为0。序列为升序。忽略该子句时,缺省值为1。 START WITH:指定生成的第一个序列号。在升序时,不能小于最小值,缺省值为序列的最小值。对于降序,序列可由比最大值小的值开始,缺省值为序列的最大值。 MAXVALUE:指定序列可生成的最大值。NOMAXVALUE:为升序指定最大值为1027,为降序指定最大值为-1。 MINVALUE:指定序列的最小值。NOMINVALUE:为升序指定最小值为1。为降序指定最小值为-1026。 NOCYCLE:一直累加,不循环。CYCLE:循环。 CACHE n:缓存n个序列值,NOCACHE:不缓存。 创建序列 创建序列 DEPT_DEPTID_SEQ为表 DEPARTMENTS 提供主键 不使用 CYCLE 选项 查询序列 查询数据字典视图 USER_SEQUENCES获取序列定义信息 如果指定NOCACHE 选项,则列LAST_NUMBER 显示序列中下一个有效的值 NEXTVAL 和 CURRVAL 伪列 只能在使用NEXTVAL后才能使用CURRVAL NEXTVAL 返回序列中下一个有效的值,任何用户都可以引用 CURRVAL 中存放序列的当前值 NEXTVAL 应在 CURRVAL 之前指定 ,二者应同时有效 序列应用举例 序列 DEPT_DEPTID_SEQ 的当前值 使用序列 将序列值装入内存可提高访问效率 序列在下列情况下出现裂缝: 回滚 系统异常 多个表同时使用同一序列 如果不将序列的值装入内存(NOCACHE), 可使用表 USER_SEQUENCES 查看序列当前的有效值 修改序列 修改序列的增量, 最大值, 最小值, 循环选项, 或是否装入内存 修改序列的注意事项 必须是序列的拥有者或对序列有 ALTER 权限 只有将来的序列值会被改变 改变序列的初始值只能通过删除序列之后重建序列的方法实现 其它的一些限制 删除序列 使用DROP SEQUENCE 语句删除序列 删除之后,序列不能再次被引用 索引 索引: 一种数据库对象 通过指针加速 Oracle 服务器的查询速度 通过快速定位数据的方法,减少磁盘 I/O 索引与表相互独立 Oracle 服务器自动使用和维护索引 创建索引 自动创建: 在定义 PRIMARY KEY 或 UNIQUE 约束后系统自动在相应的列上创建唯一性索引 手动创建: 用户可以在其它列上创建非唯一的索引,以加速查询 创建索引 在一个或多个列上创建索引 在表 EMPLOYEES的列 LAST_NAME 上创建索引 什么时候创建索引 以下情况可以创建索引: 列中数据值分布范围很广 列中包含大量空值 列经常在 WHERE 子句或连接条件中出现 表经常被访问而且数据量很大 ,访问的数据大概占数据总量的2%到4% 什么时候不要创建索引 下列情况不要创建索引: 表很小 列不经常作为连接条件或出现在WHERE子句中 查询的数据大于2%到4% 表经常更新 加索引的列包含在表达式中 查询索引 可以使用数据字典视图USER_INDEXES 和 USER_IND_COLUMNS 查看索引的信息 基于函数的索引 基于函数的索引是一个基于表达式的索引 索引表达式由列, 常量, SQL 函数和用户自定义的函数 删除索引 使用DROP INDEX 命令删除索引 删除索引UPPER_LAST_NAME_IDX 只有索引的拥有者或拥有DROP ANY INDEX权限的用户才可以删除索引 同义词 使用同义词访问相同的对象: 方便访问其它用户的对象 缩短对象名字的长度 创建和删除同义词 为视图DEPT_SUM_VU 创建同义词 删除同义词 总结 通过本章学习,您已经可以: 使用序列 通过数据字典视图 USER_SEQUENCES 查看序列信息 使用
文档评论(0)