
视图一方面可以帮我们使用表的一部分而不是所有的表,另一方面也可以针对不同的用户制定不同的查询视图。
比如,针对一个公司的销售人员,我们只想给他看部分数据,而某些特殊的数据,比如采购的价格,则不会提供给他;人员薪酬是个敏感的字段,只给某个级别以上的人员开放,其他人的查询视图中则不提供这个字段。
视图是一种 虚拟表 ,本身是 不具有数据 的。视图是建立在已有表的基础上, 视图赖以建立的这些表称为基表。

CREATE [OR REPLACE] # 创建或如果视图已经存在替换视图
# [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW 视图名称 [(字段列表)] # 字段列表为查询出来的字段取别名
AS 查询语句
[WITH [CASCADED|LOCAL] CHECK OPTION]
当使用WITH CHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如,插入,更新,删除,以使其符合视图的定义。 MySQL允许基于另一个视图创建视图,会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了两个选项: CASCADED 和 LOCAL ,默认值为 CASCADED 。
CASCADED:级联检查条件,MySQL会一直往上检查,直到关联到真实的表数据。
LOCAL:MySQL只会检查当前视图的规则
精简版:
CREATE VIEW 视图名称
AS 查询语句
CREATE VIEW v_emp1
AS
SELECT employee_id, last_name, salary
FROM employees;
SELECT * FROM v_emp1;

创建视图时,查询语句中字段的别名会作为视图的字段名。
CREATE VIEW v_emp2
AS
SELECT employee_id emp_id, last_name l_name, salary sal
FROM employees;
SELECT * FROM v_emp2;

创建视图时,可以通过指定视图的字段列表为查询出来的字段取别名。
# 字段列表中字段的个数与SELECT中字段的个数相同
CREATE VIEW v_emp3(emp_id, l_name, sal)
AS
SELECT employee_id, last_name, salary
FROM employees;
SELECT * FROM v_emp3;

CREATE VIEW v_dep_avg_sal
AS
SELECT department_id, AVG(salary) avg_sal
FROM employees
GROUP BY department_id;
SELECT * FROM v_dep_avg_sal;

CREATE VIEW v_emp_dep
AS
SELECT e.employee_id, e.department_id, d.department_name
FROM employees e
JOIN department d ON e.department_id = d.department_id;
SELECT * FROM v_emp_dep;

需要输出某个格式的内容,比如我们想输出员工姓名和对应的部门名,对应格式为emp_name(department_name),就可以使用视图来完成数据格式化的操作。
CREATE VIEW v_emp_dept1
AS
SELECT CONCAT(e.last_name, '(', d.department_name, ')') emp_dept_name
FROM employees e
JOIN department d ON e.department_id = d.department_id;
SELECT * FROM v_emp_dept1;

CREATE VIEW v_emp4
AS
SELECT employee_id, last_name
FROM v_emp1;
SELECT * FROM v_emp4;

SHOW TABLES;

DESC / DESCRIBE 视图名称;
DESC v_emp1;

# 查看视图信息(显示数据表的存储引擎、版本、数据行数和数据大小等)
SHOW TABLE STATUS LIKE '视图名称';
SHOW TABLE STATUS LIKE 'v_emp1';


执行结果显示,注释Comment为VIEW,说明该表为视图,其他的信息为NULL,说明这是一个虚表。
SHOW CREATE VIEW 视图名称;
SHOW CREATE VIEW v_emp1;

MySQL支持使用INSERT、UPDATE和DELETE语句对视图中的数据进行插入、更新和删除操作。当视图中的数据发生变化时,数据表中的数据也会发生变化,反之亦然。
SELECT * FROM v_emp1;
UPDATE v_emp1
SET salary = 20000
WHERE employee_id = 102;
SELECT * FROM v_emp1;
SELECT *
FROM employees
WHERE employee_id = 102;



要使视图可更新,视图中的行和底层基本表中的行之间必须存在 一对一 的关系。
示例:

将每个部门的平均工资修改为2000,Mysql不能进行修改,因为平均工资是由每一行通过计算得到的,修改后不知道值如何进行分配到每一行。
虽然可以更新视图数据,但总的来说,视图作为 虚拟表 ,主要用于 方便查询 ,不建议更新视图的数据。对视图数据的更改,都是通过对实际数据表里数据的操作来完成的。
CREATE OR REPLACE VIEW v_emp1
AS
SELECT employee_id, last_name, salary, email
FROM employees;
DESC v_emp1;

语法:
ALTER VIEW 视图名称
AS
查询语句
代码示例:
ALTER VIEW v_emp1
AS
SELECT employee_id, last_name, salary, email, hire_date
FROM employees;
DESC v_emp1;

删除视图只是删除视图的定义,并不会删除基表的数据。
语法:
DROP VIEW IF EXISTS 视图名称1 [,视图名称2,视图名称3,...];
代码示例:
SHOW TABLES;
DROP VIEW IF EXISTS v_emp_dept1;
SHOW TABLES;


注意:基于视图a、b创建了新的视图c,如果将视图a或者视图b删除,会导致视图c的查询失败。这样的视图c需要手动删除或修改,否则影响使用。