1.什么是视图?

  视图(VIEW)也被称为虚表,即虚拟的表,是一组数据的逻辑表达

  视图对应于一条SELECT语句,结果集被赋予一个名字, 即视图名字

  视图本身不包含任何数据,只是映射到基表的一个查询语句,当基表数据发生变化,视图数据也随之发送变化

  作用:重用代码,保护数据

2.创建视图 需要有权限 GRANT CREATE VIEW  TO user scott;

CREATE VIEW view_name 别名

不包含函数 叫简单视图

包含函数 表达式 复杂视图

基于多个表 连接视图

OR REPLACE 更新视图 如果存在则替换

语法

CREATE OR REPLACE VIEW 视图名称 SELECT语句

隐藏列名称 在SELECT语句中增加别名

CREATE OR REPLACE VIEW v_emp_10 AS SELECT empno id, ename name,sal salary,deptno deptno FROM emp WHERE deptno=10;

查看视图结构 DESC 视图名称

增加别名后 只能用别名进行查询视图 SELECT 姓名,工资,工作 FROM v_emp_10;

增加 WITH CHECK OPTION 防止在简单视图模式下 插入脏数据到基表内

CREATE OR REPLACE VIEW v_emp_10 AS SELECT empno id,

ename name,sal salary,deptno deptno FROM emp WHERE deptno=10 WITH CHECK OPTION;

复杂视图的创建

CREATE VIEW v_emp_salary

AS

SELECT d.dname,

AVG(e.sal) avg_sal,

SUM(e.sal) sum_sal,

MAX(e.sal)max_sal,

MIN(e.sal) min_sal

FROM emp e JOIN dept d ON e.deptno =d.deptno GROUP BY d.dname;

复杂视图的查询

SELECT * FROM v_emp_salary;

复杂视图不允许DML操作