目录
一、序列篇
1、什么是序列
2、创建序列
语法说明:
创建序列demo
3、查看序列
4、序列的属性(伪列)
1.nextval
2.currval
5、如何使用序列
6、修改序列
语法说明:
修改序列demo
7、删除序列
二、视图篇
1、什么是视图
2、视图的存储
3、视图的优势
4、视图的分类
两种视图的比较
5、创建视图
视图语法说明
创建视图demo
6、如何使用视图
7、给视图的列起别名
8、查看视图信息
9、创建复杂视图
复杂视图demo
10、删除视图
删除视图demo
一、序列篇
1、什么是序列
所谓序列,在oracle中就是一个对象,这个对象用来提供一个有序的数据列,这个有序的数据列的值都不重复。
- 1.序列可以自动生成唯一值
- 2.是一个可以被共享的对象
- 3.典型的用来生成主键值的一个对象
- 4.可以替代应用程序代码
- 5.当sequence的值存放在缓存中时可以提高访问效率。
2、创建序列
CREATE SEQUENCE name [INCREMENT BY n] [START WITH n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}]
语法说明:
1.increment by n:表明值每次增长n(步长)
2.start with n: 从n开始
3.{MAXVALUE n | NOMAXVALUE}: 设置最大值
4.{MINVALUE n | NOMINVALUE}: 设置最小值,start with不能小于最小值。
5.CYCLE | NOCYCLE : 是否循环,建议不使用
6.CACHE n | NOCACHE : 是否启用缓存,缓存n个值,如果不写的话默认是缓存20个字符
创建序列demo
代码语言:javascript复制create sequence student_id_seq
start with 1
increment by 1
nomaxvalue
nominvalue
nocycle
nocache;
3、查看序列
代码语言:javascript复制select sequence_name,min_value,max_value,last_number
from user_sequences
where sequence_name = 'student_id_seq';
4、序列的属性(伪列)
1.nextval
返回下一个可用的序列值。就算是被不同的用户调用,每次也返回一个唯一的值。
2.currval
获取序列当前的值。在currval调用之前,必须保证nextval已经获取过一次值。
5、如何使用序列
1.向表中插入数据 insert into emp values(student_id_seq.nextval);
2.查看序列的当前值 select student_id_seq.currval from dual;
3.获取序列的下一个值。 select student_id_seq.nextval from dual;
缓存:使用缓存可以提高sequence的访问效率
6、修改序列
ALTER SEQUENCE name [INCREMENT BY n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}]
语法说明:
1.必须是序列的拥有者,或者具有alter权限 2.修改后的序列,只对之后的值起作用。 3.除了start with不可以改,其他都能修改,如果想改,只能删除,重新创建,启动。
修改序列demo
代码语言:javascript复制alter sequence student_id_seq
increment by 2
maxvalue 100
cycle;
7、删除序列
drop sequence 序列名称;
删除序列demo
代码语言:javascript复制drop sequence student_id_seq;
二、视图篇
1、什么是视图
所谓视图就是提取一张或者多张表的数据生成一个映射,管理视图可以同样达到操作原表的效果,方便数据的管理以及安全操作。 视图其实就是一条查询sql语句,用于显示一个或多个表或其他视图中的相关数据。视图将一个查询的结果作为一个表来使用,因此视图可以被看作是存储查询结果的一个虚拟表。视图来源于表,所有对视图数据的修改最终都会被反映到视图的基表中,这些修改必须服从基表的完整性约束。
2、视图的存储
与表不同,视图不会要求分配存储空间,视图中也不会包含实际的数据。视图只是定义了一个查询,视图中的数据是从基表中获取,这些数据在视图被引用时动态的生成。由于视图基于数据库中的其他对象,因此一个视图只需要占用数据字典中保存其定义的空间,而无需额外的存储空间。
3、视图的优势
- 1.可以达到信息的隐藏,比如employees表中有工资,可以创建视图,隐藏工资信息。(可以配合权限,让某个用户只能查看视图,不能查看表。)
- 2.使复杂查询变得简单。
- 3.数据独立
- 4.相同数据的不同展示形式。
4、视图的分类
1.简单视图
2.复杂视图
两种视图的比较
简单视图 | 复杂视图 | |
---|---|---|
涉及到的表个数 | 1 | 1个或多个 |
包含函数 | 不包含 | 包含 |
包含组数据 | 不包含 | 包含 |
通过视图使用DML语法 | 可以 | 不可以 |
可以在视图里插入数据,会更新到基表中;在基表中插入数据,也会更新到视图中
5、创建视图
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias[, alias]...)] AS select 。。。。 [WITH CHECK OPTION [CONSTRAINT constraint]] [WITH READ ONLY]
视图语法说明
- 1.or replace:代表修改view,就是原先已经创建了的话,再次创建同名的就会替换掉
- 2.force| noforce: 即使基表不存在也要建立该视图 | 基表不存在就不建立此视图,默认值。
- 3.alias: 视图中的列的名字(相当于给子查询的结果列起别名)
- 4.子查询中可以包含复杂的查询语法,这些细节都对用户隐藏。
- 5.子查询中不能包含order by子句。
- 6.WITH CHECK OPTION 插入或修改的数据行必须满足视图定义的约束;换句话说,加上该关键词表示对view进行dml操作的时候,只能操作select语句中where条件限制的内容
- 7.WITH READ ONLY :该视图只读,不能在这个视图上进行任何DML操作。
- 8.查看视图结构: desc view_name;
创建视图demo
代码语言:javascript复制create or replace view myView
as
select id,last_name,start_date
from s_employees
where id <= 100;
6、如何使用视图
1.查看视图中所有数据信息 select * from myView; 2.执行插入: insert into myView values(111,'haha','03-5月-16'); 插入成功! 3.再次查看,找不到刚插入的数据,因为这条数据不满足id<=100,但是查看原始表s_employees,有这条数据。
7、给视图的列起别名
create or replace view myView (id,name,s_date) as select id,last_name,start_date from s_employees; 或者使用 create or replace view myView as select id,last_name,start_date s_date from s_employees; myView中列的名字都为id,name,s_Date. 两者效果相同。
8、查看视图信息
可以使用数据字典user_views;
代码语言:javascript复制1、desc user_views;
2、select view_name from user_views;
9、创建复杂视图
复杂视图可能包含分组,组函数,多表连接等。
复杂视图demo
代码语言:javascript复制CREATE or replace VIEW myView
(name, minsal, maxsal, avgsal)
AS SELECT d.name, MIN(e.salary),
MAX(e.salary), AVG(e.salary)
FROM s_employees e, s_dept d
WHERE e.dept_id = d.id
GROUP BY d.name;
10、删除视图
drop view 视图名称;
删除视图demo
代码语言:javascript复制drop view myView