视图和子查询

2024-06-17 22:12
文章标签 查询 视图 和子

本文主要是介绍视图和子查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

视图及子查询

假如我们有一张表,表名为 person,如下所示:

+-----------+------------+-----------+------+-------------+-----------+
| person_id | first_name | last_name | age  | city        | country   |
+-----------+------------+-----------+------+-------------+-----------+
|         1 | John       | Doe       |   30 | New York    | USA       |
|         2 | Jane       | Smith     |   25 | Los Angeles | USA       |
|         3 | Alice      | Johnson   |   35 | London      | UK        |
|         4 | Bob        | Brown     |   40 | Sydney      | Australia |
|         5 | Emma       | Garcia    |   28 | Madrid      | Spain     |
+-----------+------------+-----------+------+-------------+-----------+

视图

视图是一个虚拟的表,其内容基于对一个或多个实际表进行的查询结果。它实际上是一个 SQL 查询的结果集,但可以像表一样被查询、访问和操作。视图本身不存储数据,而是存储了对其他表的查询定义。通过创建视图,可以简化复杂的查询、隐藏数据结构、提供安全性以及实现数据抽象。

创建视图的语法通常如下:

create view 视图的名称 as
select 列名1, 列名2, ...
from 表名
where 可选的筛选条件;
  • 可修改的视图:创建一个基于 person 表的视图。

    create view editable_person_age_view as
    select person_id, first_name, last_name, age
    from person;-- 这里省略查询视图的语句。
    +-----------+------------+-----------+------+
    | person_id | first_name | last_name | age  |
    +-----------+------------+-----------+------+
    |         1 | John       | Doe       |   30 |
    |         2 | Jane       | Smith     |   25 |
    |         3 | Alice      | Johnson   |   35 |
    |         4 | Bob        | Brown     |   40 |
    |         5 | Emma       | Garcia    |   28 |
    +-----------+------------+-----------+------+
    

    接下来我们对这个视图进行一个简单的修改:

    update editable_person_age_view
    set age = 40
    where person_id = 2;-- 这里省略查询视图的语句。
    +-----------+------------+-----------+------+
    | person_id | first_name | last_name | age  |
    +-----------+------------+-----------+------+
    |         1 | John       | Doe       |   30 |
    |         2 | Jane       | Smith     |   40 |
    |         3 | Alice      | Johnson   |   35 |
    |         4 | Bob        | Brown     |   40 |
    |         5 | Emma       | Garcia    |   28 |
    +-----------+------------+-----------+------+
    5 rows in set (0.00 sec)
    

    这个更新操作将更新 editable_person_age_view 视图中 person_id 为 2 的人员的年龄信息为 40 岁。

    什么样的视图可以进行修改?

    • 视图中的每一列都来自于唯一的基表中的列。
    • 视图中的每一列都是可以通过唯一值确定的表达式的结果。

    我们上面创建的 editable_person_age_view 是可修改的,因为它们只从 person 表中查询数据,且不进行列的计算或处理。

  • 不可修改的视图:创建一个基于 person 表的视图。

    create view city_population_view as
    select city, count(*) as population
    from person
    group by city;-- 这里省略查询视图的语句。
    +-------------+------------+
    | city        | population |
    +-------------+------------+
    | New York    |          1 |
    | Los Angeles |          1 |
    | London      |          1 |
    | Sydney      |          1 |
    | Madrid      |          1 |
    +-------------+------------+
    5 rows in set (0.00 sec)
    

    这个视图包含了聚合函数 count(*)group by 子句,因此是不可修改的。

  • 删除视图

    删除视图的语法如下:

    drop view  view_name;
    

    其中drop view 是 SQL 删除视图的关键字,view_name 是要删除的视图的名称。

    还有一个关键字就是if exists,这是一个可选的子句,用于指定当视图不存在时是否给出警告。如果省略了此子句,并且视图不存在,则会出现错误。使用 if exists 可以避免因尝试删除不存在的视图而导致的错误。其语法为:

    drop view [if exists] view_name;
    

子查询

子查询是指在 SQL 查询中嵌套另一个查询的查询结构。子查询可以用作 SQL 语句中的一个组成部分,用于过滤结果、提供计算的值或与主查询进行比较。子查询可以出现在 selectINSERTupdatedelete 语句中的多个位置。子查询可以分为两种类型:

内部子查询:内部子查询是嵌套在其他查询中的子查询,通常出现在 where 子句中的条件中。内部子查询返回一个结果集,该结果集用于过滤主查询中的数据。

外部子查询:外部子查询是独立于主查询的子查询,通常出现在主查询的列列表或条件中。外部子查询的结果集用于与主查询中的列进行比较或用作值。

  • 内部子查询

    select *
    from person
    where age > (select AVG(age) from person);+-----------+------------+-----------+------+-------------+-----------+
    | person_id | first_name | last_name | age  | city        | country   |
    +-----------+------------+-----------+------+-------------+-----------+
    |         2 | Jane       | Smith     |   40 | Los Angeles | USA       |
    |         3 | Alice      | Johnson   |   35 | London      | UK        |
    |         4 | Bob        | Brown     |   40 | Sydney      | Australia |
    +-----------+------------+-----------+------+-------------+-----------+
    

    在这个查询中,内部子查询 (select avg(age) from person) 计算了 person 表中所有人的平均年龄,然后主查询将其与 person 表中的年龄进行比较,返回年龄大于平均年龄的人员记录。

  • 外部子查询

    select p.person_id, p.first_name, p.last_name, a.age
    from person p
    inner join  (select person_id, max(age) as agefrom age_recordsgroup by person_id
    ) as a on p.person_id = a.person_id;
    

    在这个查询中,外部子查询 (select person_id, max(age) as age from age_records group by person_id) 返回了每个人员的最新年龄记录,然后主查询将其与 person 表进行连接,以获取每个人员的最新年龄信息。

理论上,子查询可以无限嵌套,但实际操作中,我们通常不推荐这样做,因为这可能会对查询效率产生负面影响。可以将子查询视为一种临时表。这种临时表在查询过程中生成,并在查询结束后立即消失。这样的设计可以帮助我们更有效地管理和操作数据。但是,为了提高查询效率,我们应尽量避免过度使用子查询。

这篇关于视图和子查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1070600

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

MySQL不使用子查询的原因及优化案例

《MySQL不使用子查询的原因及优化案例》对于mysql,不推荐使用子查询,效率太差,执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响,本文给大家... 目录不推荐使用子查询和JOIN的原因解决方案优化案例案例1:查询所有有库存的商品信息案例2:使用EX

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

Redis KEYS查询大批量数据替代方案

《RedisKEYS查询大批量数据替代方案》在使用Redis时,KEYS命令虽然简单直接,但其全表扫描的特性在处理大规模数据时会导致性能问题,甚至可能阻塞Redis服务,本文将介绍SCAN命令、有序... 目录前言KEYS命令问题背景替代方案1.使用 SCAN 命令2. 使用有序集合(Sorted Set)

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

ural 1026. Questions and Answers 查询

1026. Questions and Answers Time limit: 2.0 second Memory limit: 64 MB Background The database of the Pentagon contains a top-secret information. We don’t know what the information is — you