下面用员工表(emp)和部门表(dept)作为测试表!
员工表(emp)中包含如下字段:
部门表(dept)中包含如下字段:
CREATE VIEW view_name AS SELECT ...;
创建视图时会先执行select语句,然后用查询得到的结果来创建视图
当我们要查询每个员工及其对应的部门名称时,需要使用员工表(emp)和 部门表(dept)进行多表查询,并筛选出员工的部门号等于部门的部门号的记录。
select ename, dname from emp,dept where emp.deptno=dept.deptno;
如果该查询结果会被频繁用到,那我们就可以给上述查询结果创建视图,创建完毕后通过show命令就能看到这个视图。
create view v_ename_dname as
select ename, dname from emp,dept where emp.deptno=dept.deptno;
创建视图后就可以直接通过查询视图,来查看每个员工及其对应的部门名称了。
select * from v_ename_dname;
通过查询员工表(emp),可以看到员工CLARK所在部门的部门号为10
select * from emp where ename='CLARK';
查询部门表(dept),可以看到10号部门的部门名称为ACCOUNTING
select * from dept where deptno=10;
在视图中将员工CLARK的名字改为TEST后,会看到在员工表(emp)中的员工CLARK的名字也被改为TEST
update v_ename_dname set ename='TEST' where ename='CLARK';
select * from emp where ename='CLARK';
select * from emp where ename='TEST';
根本原因就是因为视图和基表使用的是同一份数据,将视图中员工CLARK的名字改为TEST后员工表(emp)中的员工CLARK的名字也被改为TEST!!!
通过查询员工表(emp),可以看到员工JAMES所在部门的部门号为30。
select * from emp where ename='JAMES';
30号部门的部门名为SALES,因此查询视图时可以看到JAMES所在的部门名为SALES。
select * from v_ename_dname where ename='JAMES';
现在将员工表(emp)中,员工JAMES对应的部门号改为10。
update emp set deptno=10 where ename='JAMES';
select * from v_ename_dname where ename='JAMES';
修改后再查询视图,就会发现JAMES所在部门的部门名,变成了10号部门的部门ACCOUNTING
select * from v_ename_dname where ename='JAMES';
DROP VIEW view_name;
比如将刚才创建的视图(v_ename_dname )删除后,在数据库中就看不到这个视图了
drop view v_ename_dname;