- 什么是视图
view:站在不同的角度去看待同一份数据 - 怎么创建视图对象?怎么删除视图对象?
表复制:
create table dept2 as select * from dept;
创建视图对象:
create view dept2_view as select * from dept2;
删除视图对象:
drop view dept2_view;
注意:只有DQL才能以view的形式创建
create view view_name as 这里的语句必须是DQL语句 - 用视图做什么?
我们可以面向视图对象进行增删改查,对视图对象的增删改查,会导致
原表被操作!(视图的特点:通过对视图的操作,会影响到原表数据)
//面向视图查询
select * from dept2_view;
//面向视图插入
insert into dept2_view(deptno,dname,loc) values (60,'sales','biejing');
//查询原表数据
select * from dept2; - 视图对象在实际开发中到底有什么用?《方便,简化开发,利于维护》
- 假设有一条非常复杂的SQL语句,而这条SQL语句需要在不同的位置上反复使用。
每一次使用这个sql语句的时候都需要重新编写,很长,很麻烦,怎么办? - 可以把这条复杂的SQL语句以视图对象的形式新建
在需要编写这条SQL语句的位置直接使用视图对象,可以大大简化开发
并且利于后期的维护,因为修改的时候也只需要修改一个位置就行,
只需要修改视图对象所映射的SQL语句 - 我们以后面向视图开发的时候,使用视图的时候可以像使用table一样。
可以对视图进行增删改查等操作。视图不是在内存当中,视图对象也是存储在硬盘上的,不会消失 - 视图对应的语句只能是DQL语句
但是视图对象创建完成之后,可以对视图进行增删改查等操作 - 小插曲:
增删改查,又叫做:CRUD
CRUD是在公司中程序员沟通的术语。一般我们很少说增删改查。一般都说CRUD
C:create
R:retrieve
U:update
D:delete
- 假设有一条非常复杂的SQL语句,而这条SQL语句需要在不同的位置上反复使用。