视图(mysql)

server/2024/9/22 18:10:05/

一、什么是视图

视图是⼀个虚拟的表,它是基于⼀个或多个基本表或其他视图的查询结果集。视图本⾝不存储数 据,⽽是通过执⾏查询来动态⽣成数据。⽤⼾可以像操作普通表⼀样使⽤视图进⾏查询、更新和管 理。视图本⾝并不占⽤物理存储空间,它仅仅是⼀个查询的逻辑表⽰,物理上它依赖于基础表中的数 据。

二、创建视图

sql"># 语法
CREATE VIEW view_name [(column_list)] AS select_statemen

三、使用视图

查询⽤⼾的所有信息和考试成绩

学生ID,学生姓名,所有班级名,课程和对用的成绩

sql">select s.student_id,s.name,cls.class_id,cls.name,c.course_id,c.name,sc.score
from student as s,class as cls,course as c,score as sc
where s.class_id = cls.class_idand sc.student_id = s.student_idand sc.course_id = c.course_id
order by s.student_id;

1、定义视图

sql"># 定义视图
create view v_student_score as
(
select s.student_id,s.name   as student_name,cls.class_id,cls.name as class_name,c.course_id,c.name   as course_name,sc.score
from student as s,class as cls,course as c,score as sc
where s.class_id = cls.class_idand sc.student_id = s.student_idand sc.course_id = c.course_id
order by s.student_id);

 执行代码时会出现异常

 

 解决方法:

分别对s.name、cls.name、c.name 起别名

sql"># 定义视图
create view v_student_score as
(
select s.student_id,s.name   as student_name,cls.class_id,cls.name as class_name,c.course_id,c.name   as course_name,sc.score
from student as s,class as cls,course as c,score as sc
where s.class_id = cls.class_idand sc.student_id = s.student_idand sc.course_id = c.course_id
order by s.student_id);

2、查看视图:

sql">show tables;

使用视图:

sql">show create view v_student_score;select * from v_student_score;

创建视图指定别名:

sql">create view v_student_score_v1(id, name, class_id, class_name, course_id, course_name, score)
as
(
select s.student_id,s.name,cls.class_id,cls.name,c.course_id,c.name,sc.score
from student as s,class as cls,course as c,score as sc
where s.class_id = cls.class_idand sc.student_id = s.student_id);

 通过更新视图将分数改为80分

sql">update v_student_score
set score=80
where student_id = 1and course_id = 1;

 

注意事项:

修改真实表会影响视图,修改视图同样也会影响真实表 •

以下视图不可更新: 

1、创建视图时使⽤聚合函数的视图 ◦

2、创建视图时使⽤ DISTINCT ◦

3、创建视图时使⽤ GROUP BY 以及 HAVING ⼦句 ◦

4、创建视图时使⽤ UNION 或 UNION ALL ◦

5、查询列表中使⽤⼦查询 ◦

6、在FROM⼦句中引⽤不可更新视图

sql">update v_student_score_v1 set score=80 where id = 1;select *from v_student_score_v1 order by id asc;select *from score where student_id = 1;

 不论是更新了视图还是基础表,相互都会被影响,查询出来的数据都是最新结果!

3、删除视图:

sql"># 语法
drop view view_name;

四、视图的优点

1. 简单性:视图可以将复杂的查询封装成⼀个简单的查询。例如,针对⼀个复杂的多表连接查询,可 以创建⼀个视图,⽤⼾只需查询视图⽽⽆需了解底层的复杂逻辑。

2. 安全性:通过视图,可以隐藏表中的敏感数据。例如,⼀个系统的⽤⼾表中,可以创建⼀个不包含 密码列视图,普通⽤⼾只能访问这个视图,⽽不能访问原始表。

3. 逻辑数据独⽴性:视图提供了⼀种逻辑数据独⽴性,即使底层表结构发⽣变化,只需修改视图定 义,⽽⽆需修改依赖视图的应⽤程序。使⽤到应⽤程序与数据库的解耦

4. 重命名列:视图允许⽤⼾重命名列名,以增强数据可读性。


http://www.ppmy.cn/server/117050.html

相关文章

《网络协议 - HTTP传输协议及状态码解析》

文章目录 一、HTTP协议结构图二、HTTP状态码解读1xx: 信息响应类2xx: 成功响应类3xx: 重定向类4xx: 客户端错误类5xx: 服务器错误类 一、HTTP协议结构图 二、HTTP状态码解读 HTTP状态码(英语:HTTP Status Code)是用以表示网页服务器超文本传…

【25.3】C++智能交友系统

仿照上篇文章&#xff0c;编写boy类&#xff0c;代码如下 头文件 #pragma once #include <string>using namespace std;class Girl; class Boy { public:Boy();Boy(int age, string name, int salary);~Boy();int getAge() const;string getName() const;int getSalary…

Humanize AI 简介

Humanize AI 简介 Humanize AI 官方首页截图 文章目录 Humanize AI 简介1 Humanize AI 是什么2 Humanize AI 能做什么3 Humanize AI 怎么用4 Humanize AI 怎么收费5 结论 1 Humanize AI 是什么 数字时代的当下&#xff0c;AI 人工智能已成为内容创作不可或缺的一部分。从生成文…

Mysql | 知识 | 理解是怎么加锁的

文章目录 一、怎么加行级锁的&#xff1f;二、唯一索引加锁2.1 唯一索引等值查询1、记录存在的情况2、记录不存在的情况 2.2 唯一索引范围查询a. 针对「大于」的范围查询b. 针对「大于等于」的范围查询的情况。c. 「小于」范围查询&#xff0c;记录「不存在」表中的情况d. 「小…

深入理解Linux管道

在Linux系统中&#xff0c;管道&#xff08;Pipes&#xff09;是一种强大的进程间通信&#xff08;IPC&#xff09;机制。通过管道&#xff0c;多个命令可以串联起来执行&#xff0c;前一个命令的输出作为下一个命令的输入&#xff0c;这种操作常见于Linux命令行中的流水线式操…

uniapp小程序,使用腾讯地图获取定位

本篇文章分享一下在实际开发小程序时遇到的需要获取用户当前位置的问题&#xff0c;在小程序开发过程中经常使用到获取定位功能。uniapp官方也提供了相应的API供我们使用。 官网地址&#xff1a;uni.getLocation(OBJECT)) 官网获取位置的详细介绍这里就不再讲述了&#xff0c;大…

020、二级Java选择题综合知识点(持续更新版)

1. 排序二叉树的遍历结果为有序序列的是&#xff1a;中序遍历 解释&#xff1a;中序遍历是一种遍历二叉树的方式&#xff0c;按照“左子树 -> 根节点 -> 右子树”的顺序访问节点。在排序二叉树&#xff08;BST&#xff09;中&#xff0c;这种遍历顺序会得到一个递增的有…

海外云手机有哪些推荐?

随着云手机的发展&#xff0c;越来越多的企业和个人开始使用云手机来满足他们的海外业务需求。用户可以通过云手机实现方便、快捷的海外访问&#xff0c;一般用来进行tiktok运营、亚马逊电商运营、海外社媒运营等操作。海外云手机平台有很多&#xff0c;以下是一些比较好的云手…