MySQL之视图(视图的基本使用,使用规则)

视图

视图是一张虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据表花也会影响到视图

基本使用

  • 创建视图
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将被覆盖。
  • 视图可以和表一起使用。

你可能感兴趣的:(原创,MySQL数据库)