百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL数据库常用的子查询SQL命令

wptr33 2024-11-17 16:43 47 浏览

本节主要针对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命令总结完毕,编程就这么简单,小伙伴们不妨试试,总结不易,希望大家多点赞收藏转发,在此谢谢!

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...