视图
视图是一张虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据表花也会影响到视图
基本使用
- 创建视图
create ciew 视图名 as select语句
- 案例
mysql> create view view_name as select ename,dname
from emp,dept where emp.deptno=dept.deptno;
mysql> select * from view_name;
+--------+------------+
| ename | dname |
+--------+------------+
| SMITH | RESEARCH |
| ALLEN | SALES |
| WARD | SALES |
| JONES | RESEARCH |
| MARTIN | SALES |
| BLAKE | SALES |
| CLARK | ACCOUNTING |
| SCOTT | RESEARCH |
- 修改了视图,对基表数据有影响
mysql> update view_name set dname='sales' where ename='CLARK';
mysql> select * from emp where ename='CLARK';
+--------+-------+---------+------+---------------------+---------+------+--------+
| empno | ename | job | mgr | hiredate | sal | comm | deptno |
+--------+-------+---------+------+---------------------+---------+------+--------+
| 007782 | CLARK | MANAGER | 7839 | 1981-06-09 00:00:00 | 2450.00 | NULL | 10 |
+--------+-------+---------+------+---------------------+---------+------+--------+
- 修改了基表,对视图有影响
mysql> update emp set deptno=20 where ename='JAMES';
mysql> select * from view_name where ename='JAMES';
+-------+----------+
| ename | dname |
+-------+----------+
| JAMES | RESEARCH |
+-------+----------+
- 删除视图
drop view 视图名
视图的规则和限制
- 与表一样,命名必须是唯一的(不能出现同名视图或表名)
- 创建视图数目无限制,但是要考虑复杂查询创建为视图之后的性能影响。
- 视图不能添加索引,也不能有关联的触发器或者默认值
- 视图可以提高安全性,必须具有足够的访问权限
- order by可用在视图中,但是如果从该视图检索数据select中含有order by ,那么该视图中的order by将被覆盖。
- 视图可以和表一起使用。