0基础学MySQL数据库—从小白到大牛(8)子查询

2023年 8月 15日 39.8k 0

一、子查询的使用

  • 子查询指一个查询语句嵌套在另一个查询语句内部的查询 需求:查询谁的工资比id=2的高?

方式1mysql> SELECT salary    -> FROM salary    -> WHERE userid = '2';+---------+| salary  |+---------+| 2000.00 |+---------+1 row in set (0.00 sec)mysql> SELECT userid,salary    -> FROM salary    -> WHERE salary > 2000;+--------+---------+| userid | salary  |+--------+---------+|      3 | 3000.00 ||      4 | 4000.00 ||      5 | 5000.00 |+--------+---------+3 rows in set (0.00 sec)方式2 自连接mysql> SELECT s1.userid,s1.salary FROM salary s1 JOIN salary s2 ON s1.userid = '2' AND s2.salary > s1.salary;+--------+---------+| userid | salary  |+--------+---------+|      2 | 2000.00 ||      2 | 2000.00 ||      2 | 2000.00 |+--------+---------+3 rows in set (0.00 sec)方式3 子查询mysql> SELECT userid,salary    -> FROM salary    -> WHERE salary > (    ->                 SELECT salary    ->                 FROM salary    ->                 WHERE userid = '2'    ->             );+--------+---------+| userid | salary  |+--------+---------+|      3 | 3000.00 ||      4 | 4000.00 ||      5 | 5000.00 |+--------+---------+3 rows in set (0.00 sec)

1.2子查询的基本使用

称谓的规范:外查询(或主查询)、内查询(或子查询)

  • 子查询在主查询之前执行完成。
  • 子查询的结果被主查询使用
  • 注意 子查询要在括号内将子查询放在比较的右侧单行操作符对应当行子查询,多行操作符对应多行子查询

2.子查询的分类

分类方式1:
我们按内查询的结果返回一条还是多条记录,将子查询分为 ==单行子查询==、 ==多行子查询==
分类方式2:
我们按内查询是否被执行多次,将子查询划分为==相关(或关联)子查询==和==不相关(或非关联)子查询==
相关子查询与非相关子查询的区别:

​ 子查询只执行一次,后这个结果作为主查询的条件进行执行,那么这样的子查询叫做==不相关子查询==
​ 子查询需要执行多次,再将结果反馈给外部,这种方式就称为==相关子查询==

2.1单行子查询

单行操作符:

  • =
  • !=、>、>=

2.2多行子查询

  • 也称为集合比较子查询
  • 内查询返回多行
  • 使用多行比较操作符
  • 多行子查询的操作符:IN ANY ALL SOME(同ANY)。
操作符 含义
IN 等于列表中的任意一个
ANY 需要和单行比较操作符一起使用,和子查询返回某一个值比较
ALL 需要和单行比较操作符一起使用,和子查询返回所有值比较
SOME 实际上是ANY的别名,作用相同,一般用ANY

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论