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

news/2024/11/16 5:46:26/

视图

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

1. 为什么要有视图?

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

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

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

2.视图的定义和特点

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

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

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

3. 创建视图

创建视图的语法如下:

CREATE VIEW view_name [(column_list)]
AS select_statement

更新视图的语法:

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

4. 视图的使用举例

4.1 创建表并插入数据

创建表:

CREATE TABLE students (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100) NOT NULL,age INT NOT NULL,major VARCHAR(100)
);

插入数据:

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

在这里插入图片描述

4.2 举例

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

    create view myview as select name,major from students;
    

    在这里插入图片描述

  2. 查询视图

    select * from myview;
    

    在这里插入图片描述

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

    update myview set name='alice' where name ='Alice';select * from students;
    

    在这里插入图片描述
    当修改视图中的数据时,基表的数据会改变。

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

    update students set name='bob' where name ='Bob';select * from myview;
    

    在这里插入图片描述
    当修改基表的数据时,视图的数据会改变。

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

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

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

# 进入MySQL中的test数据库目录
cd /var/lib/mysql/test# 显示数据库中的文件
ls 

在这里插入图片描述
视图文件中存储的是什么呢?
打开myview文件,看一看什么:vim myview.frm
在这里插入图片描述
这张图片显示了一个 MySQL 视图的详细信息,其中红色框内的内容是视图的定义查询语句

这段 SQL 代码表示一个名为 students 的表,从中选择了 namemajor 这两个字段,并分别给它们起了别名 namemajor。这个查询语句是创建视图时使用的原始 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内部自己操作),视图只是一个查询的结果


http://www.ppmy.cn/news/1547365.html

相关文章

RabbitMQ 全面解析:语法与其他消息中间件的对比分析

1. 引言 在分布式系统和微服务架构中,消息中间件扮演着重要的角色。它们能够解耦服务、平衡负载、提高系统的可扩展性和可靠性。RabbitMQ 是其中广受欢迎的一种。本文将从 RabbitMQ 的基础概念、语法介绍、以及与其他消息中间件的对比角度,全面剖析其在…

自定义反序列化过程

需求&#xff1a;student对象中name属性&#xff0c;序列化时将该属性映射为stuname&#xff0c;反序列化时将 Json中的NAME键值对映射到name属性中 AllArgsConstructorNoArgsConstructorGetterSetterstatic class Student {JsonProperty("stuname")private List<…

分布式----Ceph部署

目录 一、存储基础 1.1 单机存储设备 1.2 单机存储的问题 1.3 商业存储解决方案 1.4 分布式存储&#xff08;软件定义的存储 SDS&#xff09; 1.5 分布式存储的类型 二、Ceph 简介 三、Ceph 优势 四、Ceph 架构 五、Ceph 核心组件 #Pool中数据保存方式支持两种类型&…

大数据新视界 -- 大数据大厂之 Impala 性能优化:优化数据加载的实战技巧(下)(16/30)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

NAT网络工作原理和NAT类型

NAT基本工作流程 通常情况下&#xff0c;某个局域网中&#xff0c;只有路由器的ip是公网的&#xff0c;局域网中的设备都是内网ip&#xff0c;内网ip不具备直接与外部应用通信的能力。 处于内网的设备如何借助NAT来实现访问外网的应用&#xff1f; 对于开启了NAT功能的局域网…

C++内存池实现

1.内存池概念 内存池就和其他的池数据&#xff08;如线程池&#xff09;结构类似&#xff0c;由程序维护一个“池”结构来管理程序使用的内存&#xff0c;然后根据需要从内存池中申请使用内存或者向内存池中释放内存&#xff0c;来达到高效管理内存的目的。 在一般的内存管理的…

Java学习Day60:回家!(ElasticStatic)

1.what is ElasticStatic The Elastic Stack, 包括 Elasticsearch、 Kibana、 Beats 和 Logstash&#xff08;也称为 ELK Stack&#xff09;。能够安全可靠地获取任何来源、任何格式的数据&#xff0c;然后实时地对数据进行搜索、分析和可视化。 Elaticsearch&#xff0c;简称…

XML Schema 字符串数据类型

XML Schema 字符串数据类型 1. 概述 XML Schema 是一种用于定义 XML 文档结构和内容的语言。它提供了一种强大的机制来描述 XML 数据的类型、结构和约束。在 XML Schema 中&#xff0c;字符串数据类型是一种基本数据类型&#xff0c;用于表示文本数据。 2. 字符串数据类型 …