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

MySQL了解视图View (视图篇 一)

视图View是什么?

MySQL的视图是一种虚拟表,它是基于一个或多个表的查询结果构建而成的。视图并不实际存储数据,而是根据定义的查询逻辑动态生成结果。

-----------------------------------

视图的特点:

- 虚拟表:视图本身不存储数据,而是通过查询操作动态生成结果。

- 可以使用多个表:视图可以基于一个或多个表进行查询,可以包含复杂的逻辑和条件。

- 可以嵌套:视图可以嵌套使用,一个视图可以作为另一个视图的查询源。

- 可以进行数据过滤:视图可以定义查询条件,只返回满足条件的数据。

- 可以进行数据重命名:视图可以对查询结果进行列名和表名的重命名,提高查询结果的可读性。

-----------------------------------

视图的作用:

- 简化复杂查询:通过创建视图,可以将复杂的查询逻辑封装起来,简化对数据的查询操作。

- 数据安全性:通过视图,可以限制用户对数据的访问权限,只暴露必要的数据给用户,提高数据的安全性。

- 数据抽象:通过视图,可以将数据的细节隐藏起来,只暴露给用户需要的信息,提供更高层次的数据抽象。

- 数据重用:通过创建视图,可以将常用的查询逻辑封装起来,方便在多个地方重用,提高开发效率。

-----------------------------------

实例介绍

假设我们有一个名为employees的表,包含员工的id、姓名、工资、部门等信息。我们可以基于这个表创建各种不同的视图,来展示员工信息的不同方面。

1、简化复杂查询:

我们需要经常查询某个部门中工资最高的员工信息。

--  创建一个视图

create view highest_salary_employees as

select * from employees

where salary = (select max(salary) from employees); 

-- 通过这个视图,直接查询工资最高的员工信息,而无需每次编写复杂的子查询

select * from highest_salary_employees ;

2. 数据安全性:

假设我们希望限制某些用户只能查看自己所在部门的员工信息

-- 创建一个名为的视图

create view department_employees as

select * from employees

where department = '销售部';

-- 通过这个视图,该用户只能查看自己所在部门的员工信息,提高了数据的安全性

select * from  department_employees;

3. 数据抽象:

假设我们需要向用户展示员工信息,但不希望暴露敏感的工资信息。

-- 创建视图

create view public_employees as

select id, name, department

from employees;

-- 通过视图,我们只暴露了员工的id、姓名和部门信息,对工资等敏感信息进行了抽象。

select * from public_employees;

4. 数据重用:

假设我们需要在多个查询中使用某个特定的员工子集。

-- 创建视图

create view sales_employees as

select * from employees

where department = '销售部门';

-- 通过视图,可以在不同的查询中重用销售部门的员工信息,提高了数据的重用性和查询效率(下面只是简单查询,实际应该复杂)

select * from sales_employees;

下一篇:

http://www.lryc.cn/news/177746.html

相关文章:

  • 使用applescript自动化trilium的数学公式环境
  • idea中maven项目打包成jar,报错没有主清单属性解决方法
  • Caddy Web服务器深度解析与对比:Caddy vs. Nginx vs. Apache
  • 基于PHP+MySQL的家教平台
  • 吉利微型纯电,5 万元的快乐
  • Gitee使用方法
  • 前端适配笔记本缩放125%,150%导致页面错乱问题
  • 多线程的学习中篇下
  • 贪心算法-拼接字符串使得字典顺序最小问题
  • Linux--互斥锁
  • [2023.09.21]:源码已上传,供大家了解Rust Yew的前后端开发
  • 时序分解 | Matlab实现CEEMD互补集合经验模态分解时间序列信号分解
  • linux缓存-利用缓存提高性能的编程技巧
  • Socks5代理、IP代理与其在爬虫开发中的应用
  • 【C++】C++继承——切片、隐藏、默认成员函数、菱形
  • WebGL笔记:WebGL中绘制圆点,设定透明度,渲染动画
  • 华为云云耀云服务器L实例评测 | 实例使用教学之简单使用:通过命令行管理华为云云耀云服务器
  • 微信小程序 课程签到系统
  • 如何用Postman做接口自动化测试
  • 支付宝电脑网站支付,异步通知
  • 【广州华锐互动】奶牛养殖难产助产3D沉浸式教学平台
  • IDEA社区版,真香!
  • SpringBoot实现全局异常处理
  • Day05-循环高级和数组
  • 从代码操作层面解释什么是“面相对象编程”?
  • 【MySQL】SQL优化、char、varchar、外键约束、排查慢sql等重点知识汇总
  • git管理常用命令
  • Python 逢七拍手小游戏2.0
  • 基于微信小程序的在线小说阅读系统,附数据库、教程
  • 216. 组合总和 III