Oracle19C入门到熟练014-数据库对象

学习要求

有一定关系型数据的操作功底,会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;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浪飞yes

我对钱没兴趣~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值