视图和子查询

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

相关文章

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

MYSQL关联关系查询方式

《MYSQL关联关系查询方式》文章详细介绍了MySQL中如何使用内连接和左外连接进行表的关联查询,并展示了如何选择列和使用别名,文章还提供了一些关于查询优化的建议,并鼓励读者参考和支持脚本之家... 目录mysql关联关系查询关联关系查询这个查询做了以下几件事MySQL自关联查询总结MYSQL关联关系查询

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

查询Oracle数据库表是否被锁的实现方式

《查询Oracle数据库表是否被锁的实现方式》本文介绍了查询Oracle数据库表是否被锁的方法,包括查询锁表的会话、人员信息,根据object_id查询表名,以及根据会话ID查询和停止本地进程,同时,... 目录查询oracle数据库表是否被锁1、查询锁表的会话、人员等信息2、根据 object_id查询被

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