• 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;

    下一篇:MySQL 视图View的SQL语法和更新(视图篇 二)

  • 相关阅读:
    查找最大元素
    脚手架搭建项目package.json配置中依赖的版本问题
    优雅处理返回信息状态码:Result对象在Spring Boot中的应用
    学习记录11
    JavaScript中如何确定this的值?如何指定this的值?
    为什么浮点数不能和0直接比较
    GPT学习-使用embedding做回归(regression)预测
    五万字 | 深入理解Linux内存管理
    全局异常处理+JSR303验证
    Spark开源REST服务——Apache Livy(Spark 客户端)
  • 原文地址:https://blog.csdn.net/DU9999999/article/details/133386627