文章目录
- [一. 基本使用](#一. 基本使用)
- [二. 视图规则和限制](#二. 视图规则和限制)
- 结束语
视图是一个虚拟表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据。
视图的数据变化会影响到基表,基表的数据变化也会影响到视图
一. 基本使用
- 创建视图
sql
create view 视图名 as select 语句;
现有如下表
sql
mysql> select * from su;
+------+------+
| id | name |
+------+------+
| 1 | jack |
| 2 | tom |
| 3 | kity |
| 4 | nono |
+------+------+
mysql> select * from exam;
+------+-------+
| id | grade |
+------+-------+
| 1 | 56 |
| 2 | 76 |
| 11 | 8 |
+------+-------+
通过笛卡尔积将两表连接,结果如下:
sql
mysql> select su.id,name,grade from exam,su where exam.id=su.id;
+------+------+-------+
| id | name | grade |
+------+------+-------+
| 1 | jack | 56 |
| 2 | tom | 76 |
+------+------+-------+
通过创建视图,保存查询结果
sql
mysql> create view test as select su.id,name,grade from exam,su where exam.id=su.id;
mysql> select * from test;
+------+------+-------+
| id | name | grade |
+------+------+-------+
| 1 | jack | 56 |
| 2 | tom | 76 |
+------+------+-------+
- 修改视图,对基表数据也有影响
sql
mysql> update test set name='Amy' where id=2;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from test;
+------+------+-------+
| id | name | grade |
+------+------+-------+
| 1 | jack | 56 |
| 2 | Amy | 76 |
+------+------+-------+
2 rows in set (0.00 sec)
mysql> select * from su;
+------+------+
| id | name |
+------+------+
| 1 | jack |
| 2 | Amy |
| 3 | kity |
| 4 | nono |
+------+------+
-
修改基表,对视图同样有影响(这里不作演示了)
-
删除视图
sql
drop view 视图名
二. 视图规则和限制
- 与表一样,必须唯一命名(不能出现同名表或同名视图)
- 创建视图数目无限制,但要考虑复杂查询创建为视图之后的性能影响
- 视图不能添加索引,也不能有关联得触发器或者默认值
- 视图可以提高安全性,必须有足够的访问权限
order by
可以在视图中使用,但如果select语句中有order by,那视图的order by 无效- 视图可以和表一起使用
结束语
如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。