当前位置: 首页 > article >正文

MySQL数据库-视图的介绍和使用

视图

1.视图的概念

视图:由数据库中一张表或多张表根据特定的条件查询出的数据构造成的虚拟表。

1.1 视图的作用
  • 安全性:如果我们直接将数据表授权给用户操作,则用户可以CRUD数据表中所有数,假如我们想要对数据表中的部分数据进行保护,可以将公开的数据,生成视图,授权用户访问视图。用户可以查询视图获取数据表中的公开数据,从而达到将数据表中的部分数据对用户隐藏;
  • 简单性:如果我们需要查询的数据来源多张表,可以使用多表连接查询。而视图的使用,可以让我们通过视图将这些连接查询结果对用户开放,用户则可以直接通过查询视图,获取多表数据,操作更加方便。

2 创建视图

2.1 语法
create view view_name 
AS
select _statement
2.2 视图案例

案例1

-- 创建视图:将学生表中性别为男的学生信息创建一张视图
CREATE VIEW view_stu_denger
AS
SELECT * from students where stu_denger = '男';

-- 查询视图
SELECT * from view_stu_denger;

案例2

-- 创建视图:查询学生借书的信息(学生名、图书名、借书数量)
CREATE VIEW view_stu_records
AS
select s.stu_name,b.book_name,r.borrow_num 
from 
students s INNER JOIN books b INNER JOIN records r 
ON 
s.stu_num = r.snum and b.book_id = r.bid;

-- 查询视图(视图的查询结果,学生表、图书表、借书表的联合查询结果的展示)
SELECT * from view_stu_records;
2.3 视图数据的特性

视图是虚拟表,查询视图的数据是来源于数据表的,当对视图进行操作时,对原数据中的数据是否有影响?

查询操作:

  • 如果在原数据表中新增数据,且满足视图的查询条件,通过查询视图,也可以查询出新增数的数据。
  • 如果在原数据表中删除数据,且满足视图的查询条件,通过查询视图,即查询不到已删除的数据。

新增数据

  • 如果在视图中添加数据,数据会被添加到原数据表
-- 在视图中新增数据
INSERT INTO view_stu_denger VALUES('1006','鲁班','男',18);

-- 查询视图
SELECT * from view_stu_denger;

-- 查询原表
SELECT * from students;

删除数据

  • 如果从视图删除数据,数据也将从原表中删除。
-- 删除数据
DELETE from view_stu_denger where stu_num = '1006';

-- 查询视图
SELECT * from view_stu_denger;

-- 查询原表
SELECT * from students;

修改数据

  • 如果在视图中修改数据,源数据表中的数据也将同步修改
-- 在视图中修改数据
UPDATE view_stu_denger set stu_age = 32 where stu_num = '1003';

-- 查询视图
SELECT * from view_stu_denger;

-- 查询原表
SELECT * from students;

注意: 对于多表查询,连接查询的视图,是不能进行增删改的操作!

**视图的使用建议:**对复杂查询简化操作,并且不会对数据进行修改的情况下可以使用视图。

3.对视图的操作

3.1查询视图结构
-- 查询视图结构
DESC view_stu_records;
3.2修改视图
-- 修改视图:方式1 REPLACE
CREATE OR REPLACE VIEW view_stu_denger
AS
SELECT * from students where stu_denger = '女';

-- 修改视图:方式2 ALTER
ALTER VIEW view_stu_denger
AS
SELECT * from students where stu_denger = '男';
3.3删除视图

删除数据表是,会删除全部数据,但是删除视图时,不会删除原表数据

-- 删除视图
DROP VIEW view_stu_denger;

http://www.kler.cn/a/406230.html

相关文章:

  • nvm安装node遇到的若干问题(vscode找不到npm文件、环境变量配置混乱、npm安装包到D盘)
  • 云服务器部署WebSocket项目
  • 使用 PyTorch-BigGraph 构建和部署大规模图嵌入的完整教程
  • WebApis学习笔记,第二节:高级语法
  • 《Python制作动态爱心粒子特效》
  • json-bigint处理前端精度丢失问题
  • MYSQL——多表查询、事务和索引
  • Firewall防火墙配置
  • 【linux 免密登录】快速设置kafka01、kafka02、kafka03 三台机器免密登录
  • Java之Spring MVC篇三
  • 深入探索JMeter逻辑控制器:构建复杂测试场景的利器
  • <OS 有关> ubuntu 24 不同版本介绍 安装 Vmware tools
  • 【大数据技术基础 | 实验十二】Hive实验:Hive分区
  • Linux的桌面
  • qt调试手段
  • redis的双重hash作用
  • JavaScript 中使用 POST 获取数据全解析
  • 物业管理系统的设计和实现
  • 重学SpringBoot3-Spring Retry实践
  • 哈希表(极速学习版)
  • Oracle 到 Elasticsearch 数据迁移同步
  • 深入探索:C++红黑树原理与实现
  • 16. 整数n内含有数字2的小游戏
  • 043 商品详情
  • Rust学习(八):异常处理和宏编程:
  • linux 网络安全不完全笔记