【MySQL 保姆级教学】详细讲解视图--(15)

视图

  • [1. 为什么要有视图?](#1. 为什么要有视图?)
  • 2.视图的定义和特点
  • [3. 创建视图](#3. 创建视图)
  • [4. 视图的使用举例](#4. 视图的使用举例)
    • [4.1 创建表并插入数据](#4.1 创建表并插入数据)
    • [4.2 举例](#4.2 举例)
  • [5. 视图和基表之间有什么联系呢?](#5. 视图和基表之间有什么联系呢?)

1. 为什么要有视图?

当我们频繁地使用用多表查询和复合查询出的结果时,就需要频繁的使用多表查询和复合查询。

能不能把多表查询和复合查询的结果呢储存起来呢?并且修改查询的内容时,对应表的内容也被修改呢?

为了解决这一问题,我们就应该学习视图了

2.视图的定义和特点

MySQL的视图(View)是一种虚拟表,其内容由查询定义。从本质上讲,视图并不是以存储数据的形式存在的实体表,而是根据定义视图时所使用的查询语句动态生成的一组数据。这意味着,当你查询视图时,MySQL实际上执行的是该视图背后定义的SQL查询语句,返回的数据是基于这些查询语句从一个或多个实际表中提取出来的。(第6结还会细讲)

视图的主要特点和优势包括:

  • 简化查询 :视图可以将复杂的查询语句封装起来,使用户能够以更简单的方式查询数据,特别是当涉及到多个表的联接操作时。
  • 数据抽象:通过视图,可以隐藏表的真实结构,对外提供一个简化的数据接口,有助于保护数据库的实际设计。
  • 增强安全性:可以创建视图来限制用户对表中某些敏感数据的访问,例如,只允许用户查看某些特定的列或行。
  • 逻辑独立性:当底层表的结构发生变化时,通过调整视图的定义,可以保持应用程序不受影响,从而提高了系统的灵活性。

3. 创建视图

创建视图的语法如下:

sql 复制代码
CREATE VIEW view_name [(column_list)]
AS select_statement

更新视图的语法:

sql 复制代码
UPDATE view_name 
SET ... [where...]
  • column_list:可选参数,用于显式指定视图列的名称。
  • select_statement:定义视图的SELECT查询语句。

4. 视图的使用举例

4.1 创建表并插入数据

创建表:

sql 复制代码
CREATE TABLE students (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    age INT NOT NULL,
    major VARCHAR(100)
);

插入数据:

sql 复制代码
INSERT INTO students (name, age, major) VALUES
('Alice', 20, 'Computer Science'),
('Bob', 21, 'Mathematics'),
('Charlie', 22, 'Physics');

4.2 举例

  1. 创建视图,只需要studentsname列和major

    命令:

    sql 复制代码
    create view myview as select name,major from students;
  2. 查询视图

    sql 复制代码
    select * from myview;
  3. 修改视图中的数据后查询基表students的数据

    sql 复制代码
    update myview set name='alice' where name ='Alice';
    
    select * from students;

    当修改视图中的数据时,基表的数据会改变。

  4. 修改基表students中的数据后查询的视图的数据

    sql 复制代码
    update students set name='bob' where name ='Bob';
    
    select * from myview;

    当修改基表的数据时,视图的数据会改变。

5. 视图和基表之间有什么联系呢?

从本质上讲,视图并不是以存储数据的形式存在的实体表,而是根据定义视图时所使用的查询语句动态生成的一组数据。这意味着,当你查询视图时,MySQL实际上执行的是该视图背后定义的SQL查询语句,返回的数据是基于这些查询语句从一个或多个实际表中提取出来的。

查询一下上面创建的视图myview在Linux中的的文件

powershell 复制代码
# 进入MySQL中的test数据库目录
cd /var/lib/mysql/test

# 显示数据库中的文件
ls 

视图文件中存储的是什么呢?

打开myview文件,看一看什么:vim myview.frm

这张图片显示了一个 MySQL 视图的详细信息,其中红色框内的内容是视图的定义查询语句。

这段 SQL 代码表示一个名为 students 的表,从中选择了 namemajor 这两个字段,并分别给它们起了别名 namemajor。这个查询语句是创建视图时使用的原始 SQL 语句。

使用视图查询本质上是执行定义视图时的语句。

如:

sql 复制代码
# 创建一个视图
create view myview as select name, major from studnets;

# 查询视图的内容
select * from myview;  
# 实际上是执行
select * from
select `test`.`students`.`name` AS `name`,`test`.`students`.`major` AS `major` from `test`.`students`
# 其实就是执行
select name, major from students; 


如果对视图进行怎删改查,其实就是对基表进行增删改查(MySQL内部自己操作),视图只是一个查询的结果。

相关推荐
你的微笑,乱了夏天26 分钟前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺38 分钟前
分布式系统架构:服务容错
数据库·架构
独行soc2 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘
White_Mountain2 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
Code apprenticeship2 小时前
怎么利用Redis实现延时队列?
数据库·redis·缓存
百度智能云技术站2 小时前
广告投放系统成本降低 70%+,基于 Redis 容量型数据库 PegaDB 的方案设计和业务实践
数据库·redis·oracle
老王笔记2 小时前
GTID下复制问题和解决
mysql
装不满的克莱因瓶2 小时前
【Redis经典面试题六】Redis的持久化机制是怎样的?
java·数据库·redis·持久化·aof·rdb
Lojarro4 小时前
【Spring】Spring框架之-AOP
java·mysql·spring
梦想平凡4 小时前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle