




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第四章第四章数据库对象回顾q 锁用于保护多用户环境下被修改的数据q 锁分为两种级别,即行级锁和表级锁q 表分区允许将一个表划分成几部分,以改善大型应用系统的性能q 分区方法包括范围分区、散列分区、复合分区和列表分区q 分区维护操作包括添加、删除、截断、合并和拆分分区目标q 使用同义词q 使用序列q 创建视图q 创建索引数据库对象简介 q Oracle 数据库对象又称模式对象q 数据库对象是逻辑结构的集合,最基本的数据库对象是表q 其他数据库对象包括:数据库对象数据库对象 同义词序列视图索引同义词 3-1q同义词是现有对象的一个别名。q简化SQL语句q隐藏对象的名称和所有者q提供对对象的公共访问
2、q同义词共有两种类型:同义词私有同义词公有同义词私有同义词只能在其模式内访问,且不能与当前模式的对象同名。(比如scott用户的emp表,scott用户不能创建与emp同名的私有同义词)公有同义词可被所有的数据库用户访问。同义词 3-2CREATE SYNONYM emp FOR SCOTT.emp;SCOTT.emp的别名模式名表名私有同义词公有同义词CREATE PUBLIC SYNONYM emp_syn FOR SCOTT.emp;同义词名称同义词 3-3创建或替换现有的同义词CREATE OR REPLACE SYNONYM emp_syn FOR SCOTT.emp;替换现有的同义
3、词SQL DROP SYNONYM emp; SQL DROP PUBLIC SYNONYM emp_syn; 删除同义词序列q 序列是用于生成唯一、连续序号的对象q 序列可以是升序的,也可以是降序的q 使用CREATE SEQUENCE语句创建序列SQL CREATE SEQUENCE toys_seqSTART WITH 10INCREMENT BY 10MAXVALUE 2000MINVALUE 10NOCYCLECACHE 10;指定第一个序号从 10 开始指定序号之间的间隔为 10表示序列的最大值为 2000表示序列的最小值为 10在达到最大值后停止生成下一个值指定内存中预先分配的序
4、号数 访问序列q通过序列的伪列来访问序列的值qNEXTVAL 返回序列的下一个值qCURRVAL 返回序列的当前值SQL INSERT INTO toys (toyid, toyname, toyprice) VALUES ( toys_seq.NEXTVAL, TWENTY, 25);SQL INSERT INTO toys (toyid, toyname, toyprice) VALUES ( toys_seq.NEXTVAL, MAGIC PENCIL, 75);指定序列的下一个值SQL SELECT toys_seq.CURRVAL FROM dual;检索序列的当前值更改和删除序列S
5、QL ALTER SEQUENCE toys_seq MAXVALUE 5000 CYCLE;不能包含 start with参数值使用ALTER SEQUENCE语句修改序列,不能更改序列的START WITH参数使用DROP SEQUENCE语句删除序列SQL DROP SEQUENCE toys_seq;视图q 视图以经过定制的方式显示来自一个或多个表的数据q 视图可以视为“虚拟表”或“存储的查询”q 创建视图所依据的表称为“基表”q 视图的优点有:q 提供了另外一种级别的表安全性q 隐藏的数据的复杂性q 简化的用户的SQL命令q 隔离基表结构的改变q 通过重命名列,从另一个角度提供数据创
6、建视图 3-1studnostudnamestudmarkssubnostudcaste1Rob452Open2James334SC3Jesica405OpenStud_detailsStud_viewstudnostudnamesubno1Rob22James43Jesica5创建视图CREATE VIEW stud_viewAS SELECT studno, studname, subnoFROM Stud_details;创建视图 3-2q创建视图的语法: CREATE OR REPLACE FORCE VIEW view_name (alias, alias.) AS select_s
7、tatement创建视图 3-3使用 ORDER BY 子句创建视图CREATE OR REPLACE VIEW ord_ven ASSELECT * FROM vendor_master ORDER BY venname;创建带有错误的视图CREATE FORCE VIEW ven ASSELECT * FROM venmaster;联接视图 2-1StudnoStudnameSubmrksSubno1Rob4522James3343Jesica404SubnoSubname2English4Maths5ScienceStud_detailsSub_detailsStudnoStudname
8、SubmrksSubname1Rob45English2James33Maths3Jesica40MathsCREATE VIEW Stud_sub_view ASSELECT Studno, Studname, Submrks, SubnameFROM Stud_details, Sub_Details WHERE Stud_details.Subno=Sub_details.Subno;Stud_sub_view联接视图联接视图 2-2创建外联接视图CREATE VIEW ven_ord_outj_view ASSELECT vm.vencode, venname, orderno, od
9、ate, ostatusFROM vendor_master vm, order_master omWHERE vm.vencode = om.vencode(+);SELECT vm.vencode, venname, orderno, odate, ostatusFROM vendor_master vm LEFT OUTER JOIN order_master omON vm.vencode = om.vencode;视图上的DML语句q在视图上也可以使用修改数据的DML语句,如INSERT、UPDATE和DELETEq视图上的DML语句有如下限制:q只能修改一个底层的基表q如果修改违反
10、了基表的约束条件,则无法更新视图q如果视图包含连接操作符、DISTINCT 关键字、集合操作符、聚合函数或 GROUP BY 子句,则将无法更新视图q如果视图包含伪列或表达式,则将无法更新视图键保留表StudnoStudnameSubmrksSubno1Rob4522James3343Jesica404SubnoSubname2English4Maths5ScienceStud_detailsSub_detailsStudnoStudnameSubmarksSubnoSubname1Rob452English2James334Maths3Jesica404Maths键保留表因为 Studno
11、既是 Stud_details 中的主键,也是联接结果中的主键 Stud_details 为什么是键保留表?联接视图q 视图中可以使用单行函数、分组函数和表达式q 使用DROP VIEW语句删除视图视图中的函数CREATE VIEW item_view AS SELECT itemcode, LOWER(itemdesc) item_descFROM itemfile; SQL DROP VIEW toys_view; 索引 3-1q 索引是与表相关的一个可选结构q 用以提高 SQL 语句执行的性能q 减少磁盘I/Oq 使用 CREATE INDEX 语句创建索引q 在逻辑上和物理上都独立于表
12、的数据q Oracle 自动维护索引索引 3-2q 索引有各种类型,除了标准索引外,还有一些特殊类型的索引:索引的类型基于函数的索引反向键索引位图索引唯一索引组合索引索引 3-3SQL CREATE INDEX item_index ON itemfile (itemcode) TABLESPACE index_tbs;创建标准索引重建索引SQL ALTER INDEX item_index REBUILD; 删除索引SQL DROP INDEX item_index; 唯一索引SQL CREATE UNIQUE INDEX item_index ON itemfile (itemcode);
13、q 唯一索引确保在定义索引的列中没有重复值q Oracle 自动在表的主键列上创建唯一索引q 使用CREATE UNIQUE INDEX语句创建唯一索引组合索引SQL CREATE INDEX comp_index ON itemfile(p_category, itemrate);q 组合索引是在表的多个列上创建的索引q 索引中列的顺序是任意的q 如果 SQL 语句的 WHERE 子句中引用了组合索引的所有列或大多数列,则可以提高检索速度q 反向键索引反转索引列键值的每个字节q 通常建立在值是连续增长的列上,使数据均匀地分布在整个索引上q 创建索引时使用REVERSE关键字反向键索引SQL
14、CREATE INDEX rev_index ON itemfile (itemcode) REVERSE;SQL ALTER INDEX rev_index REBUID NOREVERSE;位图索引SQL CREATE BITMAP INDEX bit_index ON order_master (orderno);q 位图索引适合创建在低基数列上q 位图索引不直接存储ROWID,而是存储字节位到ROWID的映射q 减少响应时间q 节省空间占用基于函数的索引SQL CREATE INDEX lowercase_idx ON toys (LOWER(toyname);q 基于一个或多个列上的函数或表达式创建的索引q 表达式中不能出现聚合函数q 不能在LOB类型的列上创建q 创建时必须具有 QUERY REWRITE 权限SQL SELECT toyid FROM toys WHERE LOWER(toyname)=doll;获取索引的信息SQL SELECT INDEX_NAME, TABLE_NAME, COLUMN_NAME FROM USER_IND_CO
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 初高中学习中的心理健康问题解析
- 企业人身保险理赔方案
- 农产品安全风险评估预警
- 家电维修节约资源方案
- 地产项目竞争分析总结
- 2025中国工商银行山西省分行社会招聘120人笔试备考试题及答案解析
- 如何提高自己的沟通能力
- 云计算网络性能优化报告
- 创新个性化定制产品吸引用户
- 纺织服饰出口市场规定
- 周口市医疗保障门诊特定药品保险申请表
- 光伏电站组件清洗周边除草治理方案
- 建筑面积测绘报告范本
- 校园物业考评表
- 药品生产质量管理工程完整版课件
- 爆破作业人员培训考核题库
- 2019版外研社高中英语选择性必修三单词默写表
- 核质保监查员考试复习题(答案)
- 墙体喷射混凝土加固工程方案一
- 医学统计学SPSS
- (完整版)《危险房屋鉴定标准》JGJ125-99(2004)
评论
0/150
提交评论