网站首页 > 知识剖析 正文
本节主要针对MySQL数据库常用的子查询SQL命令进行总结,主要包括基本概念,基本定义,表现形式(SELECT语句后面,FROM语句后面,WHERE条件后面,HAVING条件后面,EXISTS运算符后面,INSERT的VALUES后面,UPDATE的SET/WHERE后面,DELETE FROM/WHERE后面),知识总结。
1.基本概念
在SQL语句中嵌套SQL语句,当一个查询是另一个查询的条件时,称之为子查询;
SQL语言允许多层嵌套查询,即一个子查询中还可以嵌套其他子查询;
以层层嵌套的方式来构造复杂的SQL语句;
子查询是本质上就是一个完整 的SELECT 语句,可以出现SQL语句的任何地方;
子查询的外部语句可以是任何一个: SELECT, INSERT, UPDATE, DELETE;
子查询可以使用在单表查询中,也可以使用在多表查询中,但必须放在()内部;
子查询的输出可以是单行单列,单行多列,多行单列,多行多列;
2.基本定义
子查询的基本定义如下:
SELECT * FROM t1 WHERE column1 = (SELECT column1 FROM t2);
//SELECT * FROM t1 WHERE... 是外部查询
//(SELECT column1 FROM t2) 是内部查询
括号内的查询叫做子查询,也叫内部查询,先于主查询执行;
子查询的结果被主查询(外部查询)使用;
3.表现形式
3.1 SELECT语句后面
// SELECT 后面,FROM前面,单行单列
//统计员工表和部门表的行数
SELECT
( SELECT COUNT(*) FROM EMP ) AS EMP_COUNT,
( SELECT COUNT(*) FROM DEPT ) AS DEPT_COUNT
FROM DUAL;
3.2 FROM语句后面
//FROM语句后面,多行多列;必须有别名;看作一个虚表/临时表;作为后续的过滤条件
//查询是经理角色的雇员并且工资在2000到3000之间的雇员信息
SELECT t.* FROM
( SELECT empno, ename, job, mgr, hiredate, sal, comm FROM EMP WHERE job = 'MANAGER' ) t
WHERE t.sal BETWEEN 2000 AND 3000;
3.3 WHERE条件后面
//查询基本工资高于公司平均薪金的全部雇员信息 (单行单列)
SELECT * FROM emp e WHERE e.sal >( SELECT AVG( sal ) FROM emp );
//查询与SCOTT从事同一工作且工资相同的雇员信息(单行多列)
SELECT * FROM emp e WHERE ( e.job, e.sal ) = ( SELECT job, sal FROM emp WHERE ename = 'SCOTT' )
AND ename <> 'SCOTT';
//查询出与每个部门中最低工资相同的全部雇员信息(多行单列)
SELECT * FROM emp e WHERE e.sal IN( SELECT MIN(sal) FROM emp GROUP BY deptno );
//查询出每个部门大于经理的工资(多行单列)
SELECT * FROM emp WHERE sal > ANY ( SELECT MIN( sal ) FROM emp WHERE job = 'MANAGER' GROUP BY deptno );
//查询出每个部门不等于经理的工资(多行单列)
SELECT * FROM emp WHERE sal <> ALL ( SELECT MIN( sal ) FROM emp WHERE job = 'MANAGER' GROUP BY deptno );
3.4 HAVING条件后面
//查询出平均薪资高于所有员工平均薪资的职位的名称、职位人数,以及这些职位的平均薪资
SELECT job,COUNT(*),AVG(sal) FROM emp
GROUP BY job HAVING AVG(sal)> (SELECT AVG(sal) FROM emp);
3.5 EXISTS运算符后面
EXISTS 运算符用于判断查询子句是否有记录;
如果有一条或多条记录存在返回 TRUE,否则返回 FALSE;
//查找符合8888这个编号的员工
SELECT * FROM emp WHERE EXISTS ( SELECT * FROM emp WHERE empno = 8888 );
//查找不符合9999这个编号的员工
SELECT * FROM emp WHERE NOT EXISTS ( SELECT * FROM emp WHERE empno = 9999 );
3.6 INSERT的VALUES后面
//员工表中created_time最大日期插入到test表中
INSERT INTO test (created_time)VALUES(SELECT MAX(created_time) FROM emp);
3.7 UPDATE的SET/WHERE后面
//update set/where 后面 子查询不能是同一张表,如果用,必须取别名;其他关联表
UPDATE test SET created_time = (SELECT created_time FROM emp WHERE id=4) WHERE id = 1;
3.8 DELETE FROM/WHERE后面
DELETE FROM test WHERE id IN (SELECT id FROM dept WHERE id <= 3);
4.知识总结
子查询的比较运算符包括单行运算符与多行运算符:
单行运算符:>、=、>=、<、<=、!=或<>
多行运算符:IN、ANY、ALL
ANY 表示和子查询的任意一个结果进行比较,有一个满足条件即可
"< ANY":表示小于子查询结果集中的任意一个,即小于最大值就可以
"> ANY":表示大于子查询结果集中的任意一个,即大于最小值就可以
"= ANY":表示等于子查询结果集中的任意一个,即等于谁都可以,相当于IN
"!=(或<>)ANY":表示不等于子查询结果中的某个值
ALL 表示和子查询的所有行结果进行比较,每一行都必须满足条件
"< ALL":表示小于子查询结果集中的所有行,即小于最小值
"> ALL":表示大于子查询结果集中的所有行,即大于最大值
"= ANL":表示等于子查询结果集中的所有行,即等于所有值,通常来说没有什么实际意义
"!=(或<>)ALL":表示不等于子查询结果中的所有值
子查询可以嵌于以下SQL语句中:
1. SELECT子句中
2. WHERE子句中
3. HAVING子句中
4. FROM子句中
5. EXISTS子句中
子查询使用总结:
1. 子查询要用括号括起来
2. 将子查询放在比较运算符的右边
3. 对于单行子查询要使用单行运算符
4. 对于多行子查询要使用多行运算符
子查询的作用:
1. 方便理解
2. 可以实现复杂逻辑的查询
3. 可以提高查询效率
至此MySQL数据库常用的子查询SQL命令总结完毕,编程就这么简单,小伙伴们不妨试试,总结不易,希望大家多点赞收藏转发,在此谢谢!
- 上一篇: 常用SQL系列之(四):Null值、插入方式、默认值及复制等
- 下一篇: 十分钟入门Fink SQL
猜你喜欢
- 2024-11-22 做测试不会 SQL?超详细的 SQL 查询语法教程来啦!
- 2024-11-22 MySQL之SQL优化
- 2024-11-22 「SQL数据分析系列」4.过滤操作
- 2024-11-22 SQL基本语句练习(基础版)
- 2024-11-22 数据分析师数据查询方法必备,SQL取数,简单查询与高级查询
- 2024-11-22 5大步骤+10个案例,堪称业内SQL优化万能公式
- 2024-11-22 SQL点滴(查询篇):数据库基础查询案例实战
- 2024-11-22 「SQL」 当我们join数据时,到底发生了什么?一文让你不再混淆
- 2024-11-22 002 Excel SQL 比较运算符的使用--OLE DB方法
- 2024-11-22 十分钟入门Fink SQL
- 04-29php开发者composer使用看这一篇就够了
- 04-29引用和变量声明在不同语言中的实作
- 04-29PHP 没你想的那么差
- 04-29Ubuntu linux 上的 Nginx 和 Php 安装
- 04-29CentOS下通过yum搭建lnmp(单版本PHP)
- 04-29为什么 PHP8 是个高性能版本
- 04-29PHP8函数包含文件-PHP8知识详解
- 04-29使用无参数函数进行命令执行
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)