MySQL视图的深度解析

文章标题:

MySQL视图的全面剖析

文章内容:

MySQL视图的深度解析

个人空间♡爱幻想的人

欢迎 👍点赞 ➕关注 ❤️收藏 💬留言


目录

🌟 一、视图的基本概念

✨1.概念

✨2.特点

🌟 二、视图的操作方法

✨1.视图的创建

语法

示例

✨2.视图的查看

语法

示例

✨3.视图的查询

语法

示例

✨4.视图数据的新增

语法

示例

✨5.视图的修改

语法

示例

✨6.视图的删除

语法

示例


🌟 一、视图的基本概念

✨1.概念

视图是一种虚拟存在的表,它基于一个或多个基础表或者其他视图的查询结果构建而成。视图自身并不实际存储数据,而是通过执行查询来动态生成相应内容。用户可以像操作普通表一样对视图进行查询、更新等操作。视图不会占用物理存储空间,它仅仅是查询的逻辑展现,其数据实际上依赖于基础表中的数据。

✨2.特点

  • 虚拟属性:视图好似一个虚拟的表,它在数据库中只保存定义该视图的查询语句,并不存储真实的数据。数据依旧存储在原始的表中,视图只是提供了一种访问数据的方式。
  • 数据独立性:视图能够将数据的逻辑结构与物理结构相分离。即便底层表的结构发生变化,只需对视图定义进行修改,无需改动依赖该视图的应用程序,从而提升了数据的独立性以及应用程序的稳定性。
  • 安全性:可以依据用户的权限和需求,视图有选择性地展示表中的部分数据和列。能够隐藏表中的敏感数据,仅向用户提供他们所需的内容,增强了数据的安全性和保密性。
  • 列重命名性:视图允许用户对列进行重命名,以增强数据的可读性。
  • 简洁性:视图能够把复杂的查询封装成一个简洁的查询。

🌟 二、视图的操作方法

✨1.视图的创建

语法

create view 视图名称[(自定义列名)] as 查询结果;

示例

-- 查询班级表中的信息
mysql> select * from class;
+----------+------------+
| class_id | class_name |
+----------+------------+
|        1 | 篮球       |
|        2 | 羽毛球     |
|        3 | 排球       |
|        4 | 乒乓球     |
+----------+------------+
4 rows in set (0.01 sec)

-- 查询学生表中的信息
mysql> select * from  students;
+----+--------+----------+
| id | name   | class_id |
+----+--------+----------+
|  1 | 小丽   |        1 |
|  2 | 莉莉   |        1 |
|  3 | 王刚   |        3 |
|  4 | 张亮   |        2 |
|  5 | 五五   |        5 |
+----+--------+----------+
5 rows in set (0.02 sec)

-- 查询两个表中班级相对应的相关信息
mysql>  select s.class_id,s.id,s.name,c.class_name from class c,students s where c.class_id=s.class_id order by class_id;
+----------+----+--------+------------+
| class_id | id | name   | class_name |
+----------+----+--------+------------+
|        1 |  1 | 小丽   | 篮球       |
|        1 |  2 | 莉莉   | 篮球       |
|        2 |  4 | 张亮   | 羽毛球     |
|        3 |  3 | 王刚   | 排球       |
+----------+----+--------+------------+
4 rows in set (0.00 sec)

-- 创建视图表:不指定列名,直接使用表中的列名。如果表中有重复的列名,那么就会创建失败
-- 将查询两个表中班级相对应的相关信息直接创建成一个视图,可以直接查询
mysql> create view v_students_class as select s.class_id,s.id,s.name,c.class_name from class c,students s where c.class_id=s.class_id order by class_id;
Query OK, 0 rows affected (0.07 sec)

-- 创建视图表:自定义视图列名,可以解决表中出现重复列名的情况
mysql> create view v1_srudents_class(class,id,name,class_name) as select s.class_id,s.id,s.name,c.class_name from class c,students s where c.class_id=s.class_id order by class_id;
Query OK, 0 rows affected (0.10 sec)

✨2.视图的查看

语法

show tables;

示例

查询所有表:

mysql> show tables;
+-------------------+
| Tables_in_java2   |
+-------------------+
| class             |
| new_class         |
| scores            |
| student_score     |
| students          |
| v1_srudents_class |
| v_students_class  |
+-------------------+
7 rows in set (0.00 sec)

✨3.视图的查询

语法

select * from 视图名称;

示例

mysql> select * from v_students_class;
+----------+----+--------+------------+
| class_id | id | name   | class_name |
+----------+----+--------+------------+
|        1 |  1 | 小丽   | 篮球       |
|        1 |  2 | 莉莉   | 篮球       |
|        2 |  4 | 张亮   | 羽毛球     |
|        3 |  3 | 王刚   | 排球       |
+----------+----+--------+------------+
4 rows in set (0.04 sec)

✨4.视图数据的新增

语法

insert into 基础表名[(列名1,列名2...)] values(列1,列2...);
  • 只能通过增加基础表中的数据,才有可能改变视图中的数据;
  • 不可以通过改变视图中的数据来改变基础表,不能通过视图直接改变视图中的数据。

示例

-- 原来的视图结果
mysql> select * from v1_srudents_class;
+-------+----+--------+------------+
| class | id | name   | class_name |
+-------+----+--------+------------+
|     1 |  1 | 小丽   | 篮球       |
|     1 |  2 | 莉莉   | 篮球       |
|     2 |  4 | 张亮   | 羽毛球     |
|     3 |  3 | 王刚   | 排球       |
+-------+----+--------+------------+
4 rows in set (0.00 sec)

-- 在学生表中新增信息
mysql> insert into students(name,class_id) values('江江',4);
Query OK, 1 row affected (0.03 sec)

-- 查询视图结果,视图结果发生改变
mysql> select * from v1_srudents_class;
+-------+----+--------+------------+
| class | id | name   | class_name |
+-------+----+--------+------------+
|     1 |  1 | 小丽   | 篮球       |
|     1 |  2 | 莉莉   | 篮球       |
|     2 |  4 | 张亮   | 羽毛球     |
|     3 |  3 | 王刚   | 排球       |
|     4 |  6 | 江江   | 乒乓球     |
+-------+----+--------+------------+
5 rows in set (0.00 sec)

-- 不能直接通过视图改变结果
mysql> insert into v1_srudents_class values(5,9,'武义','排球');
ERROR 1394 (HY000): Can not insert into join view 'java2.v1_srudents_class' without fields list

✨5.视图的修改

语法

update 视图名称 set 要修改的数据;

示例

-- 原来的学生表
mysql> select * from students;
+----+--------+----------+
| id | name   | class_id |
+----+--------+----------+
|  1 | 小丽   |        1 |
|  2 | 莉莉   |        1 |
|  3 | 王刚   |        3 |
|  4 | 张亮   |        2 |
|  5 | 五五   |        5 |
|  6 | 江江   |        4 |
+----+--------+----------+
6 rows in set (0.00 sec)

-- 修改失败:因为视图中包含order by,如果要修改要把order by移除
 update v_students_class set class_id=2 where name='江江';
ERROR 1221 (HY000): Incorrect usage of UPDATE and ORDER BY

-- 重新创建一个视图表:不包含order by
 create view v2_srudents_class(class,id,name,class_name) as select s.class_id,s.id,s.name,c.class_name from class c,students s where c.class_id=s.class_id;
Query OK, 0 rows affected (0.09 sec)

-- 再次进行修改,修改成功:将学生表中姓名为江江的学生班级更改为2班
mysql> update v2_srudents_class set class=2 where name='江江';
Query OK, 1 row affected (0.02 sec)
Rows matched: 1  Changed: 1  Warnings: 0

-- 查询更改后的视图结果
mysql> select * from v2_srudents_class;
+-------+----+--------+------------+
| class | id | name   | class_name |
+-------+----+--------+------------+
|     1 |  1 | 小丽   | 篮球       |
|     1 |  2 | 莉莉   | 篮球       |
|     3 |  3 | 王刚   | 排球       |
|     2 |  4 | 张亮   | 羽毛球     |
|     2 |  6 | 江江   | 羽毛球     |
+-------+----+--------+------------+
5 rows in set (0.00 sec)

-- 学生表中的数据也会发生改变
mysql> select * from students;
+----+--------+----------+
| id | name   | class_id |
+----+--------+----------+
|  1 | 小丽   |        1 |
|  2 | 莉莉   |        1 |
|  3 | 王刚   |        3 |
|  4 | 张亮   |        2 |
|  5 | 五五   |        5 |
|  6 | 江江   |        2 |
+----+--------+----------+
6 rows in set (0.00 sec)

✨6.视图的删除

语法

drop view 视图名称;

示例

-- 删除视图v2_srudents_class
mysql> drop view v2_srudents_class;
Query OK, 0 rows affected (0.06 sec)

-- 查看所有的表
mysql> show tables;
+-------------------+
| Tables_in_java2   |
+-------------------+
| class             |
| new_class         |
| scores            |
| student_score     |
| students          |
| v1_srudents_class |
| v_students_class  |
+-------------------+
7 rows in set (0.00 sec)

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/13071.html

(0)
LomuLomu
上一篇 2025 年 8 月 6 日
下一篇 2025 年 8 月 6 日

相关推荐

  • PyCharm破解码生成规则解析|附样例和格式说明!

    申明:本教程Pycharm 破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 Pycharm2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的Pycharm。 如果觉得破解麻烦…

    2025 年 10 月 1 日
    30300
  • 永久pycharm激活码离线激活+最新pycharm破解技巧

    声明:以下 PyCharm 2025.2.1 破解补丁与激活码均源自网络公开资源,仅限个人学习研究,禁止商业用途。若条件允许,请支持正版:https://panghu.hicxy.com/shop/?id=18(低至 32 元/年即可全家桶登录即用)。 先放一张成功激活到 2099 年的截图,爽歪歪! 下面用图文一步步带你搞定最新版 PyCharm 的破解流…

    PyCharm激活码 2025 年 12 月 1 日
    18200
  • 2025年最新IDEA激活码及永久破解教程:支持JetBrains全家桶

    前言 本教程适用于JetBrains旗下所有开发工具,包括但不限于IDEA、PyCharm、DataGrip、Goland等,堪称JetBrains全家桶的完美激活方案! 先给大家展示最新IDEA版本成功破解的截图,可以看到已经顺利激活至2099年,完全不用担心到期问题! 接下来,我将通过详细的图文步骤,手把手教你如何将IDEA永久激活至2099年。这个方法…

    IDEA破解教程 2025 年 8 月 16 日
    54600
  • ChatGPT Plus订阅还是Pro订阅?续费前先看下一周是不是忙周,判断会更准

    ChatGPT Plus订阅还是Pro订阅,续费前先看下一周是不是忙周,判断会更准这个问题,很多人一开始都会从价格入手,但真正决定体验的往往不是价目表,而是你的任务节奏、支付稳定性和续费方式是否匹配。尤其是国内用户在考虑 ChatGPT Plus充值、Plus订阅 或 Pro订阅 时,更适合先看自己到底想解决什么问题:是想把日常工作提效做稳,还是要在高峰期用…

    ChatGPT 2026 年 4 月 18 日
    7000
  • IDEA 最新激活码破解教程

    IntelliJ IDEA破解教程:永久激活IDEA 2024/2025破解补丁下载与使用指南 重要声明:本文所涉及的IntelliJ IDEA破解补丁及激活码均来源于网络收集,严禁用于商业用途,仅限个人学习研究使用。若存在侵权问题,请联系笔者进行删除。经济条件允许的话,强烈建议支持正版软件! IntelliJ IDEA是JetBrains公司推出的一款功能…

    IDEA破解教程 2026 年 1 月 6 日
    45000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信