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

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

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

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

相关推荐

[常用工具] git基础学习笔记_git工具有哪些

添加推送信息,-m=messagegitcommit-m“添加注释”查看状态...

centos7安装部署gitlab_centos7安装git服务器

一、Gitlab介1.1gitlab信息GitLab是利用RubyonRails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。...

太高效了!玩了这么久的Linux,居然不知道这7个终端快捷键

作为Linux用户,大家肯定在Linux终端下敲过无数的命令。有的命令很短,比如:ls、cd、pwd之类,这种命令大家毫无压力。但是,有些命令就比较长了,比如:...

提高开发速度还能保证质量的10个小窍门

养成坏习惯真是分分钟的事儿,而养成好习惯却很难。我发现,把那些对我有用的习惯写下来,能让我坚持住已经花心思养成的好习惯。...

版本管理最好用的工具,你懂多少?

版本控制(Revisioncontrol)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。...

Git回退到某个版本_git回退到某个版本详细步骤

在开发过程,有时会遇到合并代码或者合并主分支代码导致自己分支代码冲突等问题,这时我们需要回退到某个commit_id版本1,查看所有历史版本,获取git的某个历史版本id...

Kubernetes + Jenkins + Harbor 全景实战手册

Kubernetes+Jenkins+Harbor全景实战手册在现代企业级DevOps体系中,Kubernetes(K8s)、Jenkins和Harbor组成的CI/CD流水...

git常用命令整理_git常见命令

一、Git仓库完整迁移完整迁移,就是指,不仅将所有代码移植到新的仓库,而且要保留所有的commit记录1.随便找个文件夹,从原地址克隆一份裸版本库...

第三章:Git分支管理(多人协作基础)

3.1分支基本概念分支是Git最强大的功能之一,它允许你在主线之外创建独立的开发线路,互不干扰。理解分支的工作原理是掌握Git的关键。核心概念:HEAD:指向当前分支的指针...

云效Codeup怎么创建分支并进行分支管理

云效Codeup怎么创建分支并进行分支管理,分支是为了将修改记录分叉备份保存,不受其他分支的影响,所以在同一个代码库里可以同时进行多个修改。创建仓库时,会自动创建Master分支作为默认分支,后续...

git 如何删除本地和远程分支?_git怎么删除远程仓库

Git分支对于开发人员来说是一项强大的功能,但要维护干净的存储库,就需要知道如何删除过时的分支。本指南涵盖了您需要了解的有关本地和远程删除Git分支的所有信息。了解Git分支...

git 实现一份代码push到两个git地址上

一直以来想把自己的博客代码托管到github和coding上想一次更改一次push两个地址一起更新今天有空查资料实践了下本博客的github地址coding的git地址如果是Gi...

git操作:cherry-pick和rebase_git cherry-pick bad object

在编码中经常涉及到分支之间的代码同步问题,那就需要cherry-pick和rebase命令问题:如何将某个分支的多个commit合并到另一个分支,并在另一个分支只保留一个commit记录解答:假设有两...

模型文件硬塞进 Git,GitHub 直接打回原形:使用Git-LFS管理大文件

前言最近接手了一个计算机视觉项目代码是屎山就不说了,反正我也不看代码主要就是构建一下docker镜像,测试一下部署的兼容性这本来不难但是,国内服务器的网络环境实在是恶劣,需要配置各种镜像(dock...

防弹少年团田柾国《Euphoria》2周年 获世界实时趋势榜1位 恭喜呀

当天韩国时间凌晨3时左右,该曲在Twitter上以“2YearsWithEuphoria”的HashTag登上了世界趋势1位。在韩国推特实时趋势中,从上午开始到现在“Euphoria2岁”的Has...