学习要求
有一定关系型数据的操作功底,会SQL语句
教学目标
熟练掌握Oracle数据库对象:索引,视图,序列
索引
概念
在数据库中, 索引是除了表之外最重要的数据对象,其功能是提高对数据表的检索效率。数据库的索引类似于书的目录,通过目录,可以迅速定位书本内容。DML/DQL操作时,可以通过索引快速找到要操作的数据。
书本目录是内容与页码的清单,在数据库中,索引是数据与存储位置的列表。
索引操作注意
-
索引是一种与表相关可选数据对象,目的加速数据检索速度
-
索引是将索引列的值和行的物理记号(ROWID)排序之后存储起来,需要占用额外的存储空间。
-
索引的创建于删除,不影响数据库表数据,它是一个独立存储体系。
-
索引一旦被创建了,表数据执行DML操作时,Oracle会自动对索引进行维护,会消耗一定性能
创建
-- 单列索引
create index 索引名 on 表名(列名);
-- 联合索引
create index 索引名 on 表名(列名1,列名2);
需求:给EMP表的ename 列创建所有
create index EMP_NAME_INDEX on EMP(ENAME);
-- 查看被创建索引
select * from user_ind_columns where table_name='EMP';
-- 索引被使用验证
explain plan for select * from emp where ename = 'DAFEI';
select * from table(dbms_xplan.display);
使用PL/SQL developer 创建
drop index 索引名
需求:删除EMP表中ename 列上面的索引
drop index EMP_NAME_INDEX;
索引删除
-
索引创建不合理或者没必要,应该删除索引,以释放被占用的空间
-
如果索引没使用或者使用频率很少可以删除
-
索引含有损坏的数据块,或者包含过多存储碎片,可以先删后再重建
-
移动表数据后,导致索引失效,要删除并重建
-
一次性导入很多数据,可以先删除旧索引,导入数据后再重建索引
视图
概念
视图是由SEELCT子查询语句定义的、基于一个或多个表(或视图)的一个逻辑表,它只有定义而无数据,因此它是一个虚表。
大白话:视图就是给一条select sql进行命名,后续操作这个sql名称, 就可以执行该select语句
作用
-
提供多一种面向用户的数据表现形式
-
提供面向用户的安全性保证
-
隐藏数据的逻辑复杂性
-
简化用户权限的管理
-
重构数据库的灵活性
创建
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name
[(alias[, alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY]
OR REPLACE :若所创建的试图已经存在,ORACLE自动重建该视图;
FORCE :不管基表是否存在ORACLE都会自动创建该视图;
NOFORCE :只有基表都存在ORACLE才会创建该视图:
alias :为视图产生的列定义的别名;
subquery :一条完整的SELECT语句,可以在该语句中定义别名;
WITH CHECK OPTION :插入或修改的数据行必须满足视图定义的约束;
WITH READ ONLY :该视图上不能进行任何DML操作。
需求:给emp 表创建一个视图, 查询员工编号,员工名称,员工岗位,员工工资
-- 这里注意,创建视图需要权限:
-- 授权
conn system/admin; -- 切换用户
grant create any view to scott; -- 授权
--切换用户
conn scott/tiger;
create or replace view EMP_VIEW(no,name, job, sal)
AS
select empno, ename, job, sal from emp;
-- 使用视图
select * from emp_view; -- 跟查询普通表一样
-- 往视图中添加数据
insert into emp_view values(1200, 'view', 'SALESMAN', 1000);
select * from emp_view;
select * from emp; -- 都添加了数据
-- update视图中数据
update emp_view set name = 'view_new' where no = 1200;
-- 删除视图数据
delete from emp_view where no = 1200;
使用注意 开发中不建议对视图开放DML权限,视图定义出来初衷:1>隔绝操作原表 2>更灵活查询表
需求:定义一个视图能查询员工信息与其所在部门信息
create or replace view EMP_DEPT_VIEW(no,ename,job,hiredate,mgr,sal,comm,dno,dname)
as
select e.empno,e.ename,e.job,e.hiredate,e.mgr,e.sal,e.comm,d.deptno,d.dname
from emp e left join dept d
on e.deptno = d.deptno
with read only;
-- 测试查询
select * from emp_dept_view;
-- 测试删除
-- ORA-42399: 无法对只读视图执行 DML 操作
delete from emp_dept_view where no = 7935;
开发中使用:一般需求频繁执行某个特定sql,并且该sql编写起来非常复杂,此时可以将这个sql定义成视图方便查询。
删除视图
视图删除之后对表数据并没有造成影响,开发中这个操作要谨慎
drop view emp_dept_view;
序列
概念
序列(SEQUENCE)是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。不占
用磁盘空间,占用内存。其主要用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或
使序列增至下一个值。
类似MySQL中的id自动增长
语法
CREATE SEQUENCE 序列名
[INCREMENT BY n]
[START WITH n]
[{MAXVALUE/ MINVALUE n| NOMAXVALUE}]
[{CYCLE|NOCYCLE}]
[{CACHE n| NOCACHE}];
INCREMENT BY用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。
START WITH 定义序列的初始值(即产生的第一个值),默认为1。
MAXVALUE 定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增Oracle序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。
MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是?10的26次方;对于递增序列,最小值是1。
CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值;对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。
CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。
大量语句发生请求,申请序列时,为了避免序列在运用层实现序列而引起的性能瓶颈。Oracle序列允许将序列提前生成 cache x个先存入内存,在发生大量申请序列语句时,可直接到运行最快的内存中去得到序列。但cache个数也不能设置太大,因为在数据库重启时,会清空内存信息,预存在内存中的序列会丢失,当数据库再次启动后,序列从上次内存中最大的序列号+1 开始存入cache x个。这种情况也能会在数据库关闭时也会导致序号不连续。
NEXTVAL 返回序列中下一个有效的值,任何用户都可以引用。
CURRVAL 中存放序列的当前值,NEXTVAL 应在 CURRVAL 之前指定 ,二者应同时有效。
创建
需求:创建ID序列
create sequence id_seq increment by 1 start with 1;
-- 查看序列的当前值与后续一个值
select id_seq.currval, id_seq.nextval from dual;
需求:创建一张表,实现id自动增长
create table demo(
ID NUMBER DEFAULT id_seq.nextval,
NAME VARCHAR2(10)
);
-- 添加
insert into demo(name) values('dafei');
insert into demo(name) values('dafei');
insert into demo(name) values('dafei');
-- 查询
select * from demo;
删除
删除序列,开发中序列注意不要乱删
drop sequence id_seq;