【MySQL】视图

文章目录

  • [一. 基本使用](#一. 基本使用)
  • [二. 视图规则和限制](#二. 视图规则和限制)
  • 结束语

视图是一个虚拟表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据。

视图的数据变化会影响到基表,基表的数据变化也会影响到视图

一. 基本使用

  • 创建视图
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 无效
  • 视图可以和表一起使用

结束语

如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。

相关推荐
前行的小黑炭12 小时前
Android 协程的使用:结合一个环境噪音检查功能的例子来玩玩
android·java·kotlin
阿华的代码王国12 小时前
【Android】内外部存储的读写
android·内外存储的读写
半夏陌离14 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构
敬业小码哥14 小时前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
练小杰15 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库
inmK116 小时前
蓝奏云官方版不好用?蓝云最后一版实测:轻量化 + 不限速(避更新坑) 蓝云、蓝奏云第三方安卓版、蓝云最后一版、蓝奏云无广告管理工具、安卓网盘轻量化 APP
android·工具·网盘工具
giaoho16 小时前
Android 热点开发的相关api总结
android
感哥17 小时前
MySQL多表查询
mysql
咖啡の猫18 小时前
Android开发-常用布局
android·gitee
程序员老刘18 小时前
Google突然“变脸“,2026年要给全球开发者上“紧箍咒“?
android·flutter·客户端