学习MySQL第七天

news2025/4/8 8:54:43

 夕阳无限好           

            只是近黄昏

一、子查询

        1.1 定义

        将一个查询语句嵌套到另一个查询语句内部的查询

        我们通过具体示例来进行演示,这一篇博客更侧重于通过具体的小问题来引导大家独立思考,然后熟悉子查询相关的知识点

        1.2 问题1

        谁的工资比Tom高

方式1:
SELECT name,salary
FROM employees
WHERE name='Tom'

SELECT NAME,salary
FROM employees
WHERE salary > 500

方式2:自连接
SELECT t2.NAME,t2.salary
from employees t1,employees t2
WHERE t2.salary > t1.salary  AND 
t1.name = 'Tom'

方式3:子查询
# 外部
SELECT name,salary
FROM employees
WHERE salary > (
# 内部
  SELECT salary 
  FROM employees
  WHERE name ='Tom'
)

        1.3 称谓的规范

        (1) 外查询(主查询)、内查询(子查询) 
        (2) 子查询(内查询)在主查询之前一次执行完成
        (3) 子查询的结果被主查询(外查询)使用

        1.4 注意事项

        (1) 子查询要包含在括号内
        (2) 将子查询放在比较条件的右侧,提高可读性
        (3) 单行操作符对应单行子查询,多行操作符对应多行子查询

        1.5 子查询分类

        1.单行子查询和多行子查询
        子查询部分只返回一个值供使用,就比如C语言中副函数每次return只返回一个值,这种情况叫做单行子查询
        2.根据内查询是否被执行多次
        分为相关子查询和不相关子查询
        不相关子查询:子查询固定返回的值不受外部的影响

二、单行子查询

        2.1 单行操作符: = > < >= <=> !=
        2.2 练习1:查询工资大于id为3的员工工资的员工信息
SELECT id,name,salary
from employees
WHERE salary > (
	SELECT salary
	FROM employees
	WHERE id=3
)

        2.3 练习2:返回top_id与id=3相同的员工的工资比他多的 name、id
SELECT name,id,salary
FROM employees
WHERE top_id = (
	SELECT top_id
	FROM employees
	WHERE id = 3
) 
AND salary > (
	SELECT salary
	FROM employees
	WHERE id =3
)

        2.4 练习3:返回公司里面工资最少的人的信息,包含name、id、top_id、salary
SELECT name,id,top_id,salary
FROM employees
WHERE salary = (
	SELECT MIN(salary)
	FROM employees
)

        2.5 问题4:查询最低工资大于top_id为1的部门的最低工资的部门top_id和最低工资
SELECT top_id,MIN(salary)
FROM employees
GROUP BY top_id
HAVING MIN(salary) > (
	SELECT MIN(salary)
	FROM employees
	WHERE top_id = 1
)

三、多行子查询

        3.1 引言

        与单行查询不同的是,内查询返回多行,也就是多个值,你用一个可以选择其中的一个作为你的选择,你也可以全部都接收,但需要用同等数量的字段来接受

        3.2 命令语句

        (1) IN 等于列表中的任意一个
        (2) ANY 只选一个
        (3) SOME ANY的别名和ANY作用一样
        (4) ALL 全部选择

        3.3 练习: 这里演示一个 IN
# 查找工资等于各个top_id中最低工资的人员姓名
SELECT name,salary
FROM employees
WHERE salary IN (
				SELECT MIN(salary)
				FROM employees
				GROUP BY top_id
)

        3.4 练习: 这里演示ALL
按照top_id进行分组,求平均工资最小的那一组
SELECT top_id,AVG(salary)
FROM employees
GROUP BY top_id
HAVING avg(salary)<=ALL(
	# 小于所有部门的最小值就相当于值最小的那个组
	SELECT AVG(salary)
	FROM employees
	GROUP BY top_id 					
)

        3.5 注意

        这里我们要特别注意下空值问题,下面的题目中,我们的department_id中包含一个空值,当我们对其内查询时,就会出现错误,此时我们可以通过加注判断条件来避免

        报错演示

# 查询已经分配好部门的员工信息
# 示例
SELECT name,department_id
FROM employees
WHERE department_id NOT IN (
	SELECT department_id
	FROM employees
)

四、结语

        山不在高,有仙则名;水不在深,有龙则灵。希望我们都可以通过自己的努力成为那个关键的要素

须知少日拏云志,曾许人间第一流。我们还年轻,我们还有无限可能!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2330358.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring启示录、概述、入门程序以及Spring对IoC的实现

一、Spring启示录 阅读以下代码&#xff1a; dao package org.example1.dao;/*** 持久层* className UserDao* since 1.0**/ public interface UserDao {/*** 根据id删除用户信息*/void deleteById(); } package org.example1.dao.impl;import org.example1.dao.UserDao;/**…

电机的了解到调试全方面讲解

一、什么是电机 电机是一种将电能转换为机械能的装置,通常由定子、转子和电磁场组成。 当电流通过电机的绕组时,产生的磁场会与电机中的磁场相互作用,从而使电机产生旋转运动。电机广泛应用于各种机械设备和工业生产中,是现代社会不可或缺的重要设备之一。 常见的电机种…

笔试专题(七)

文章目录 乒乓球筐&#xff08;哈希&#xff09;题解代码 组队竞赛题解代码 删除相邻数字的最大分数&#xff08;线性dp&#xff09;题解代码 乒乓球筐&#xff08;哈希&#xff09; 题目链接 题解 1. 两个哈希表 先统计第一个字符串中的字符个数&#xff0c;再统计第二个字…

【嵌入式学习3】UDP发送端、接收端

目录 1、发送端 2、接收端 3、UDP广播 1、发送端 from socket import *udp_socket socket(AF_INET,SOCK_DGRAM) udp_socket.bind(("127.0.0.1",3333))data_str "UDP发送端数据" data_bytes data_str.encode("utf-8") udp_socket.sendto(d…

Linux 系统 SVN 源码安装与配置全流程指南

Linux系统SVN源码安装与配置全流程指南 一、环境准备 系统要求 CentOS 7及以上版本需安装GCC编译工具链 依赖项 APR/APR-UTIL&#xff08;Apache可移植运行库&#xff09;SQLite&#xff08;嵌入式数据库&#xff09;zlib&#xff08;数据压缩库&#xff09; 二、下载及安装…

Redis 的五种数据类型面试回答

这里简单介绍一下面试回答、我之前有详细的去学习、但是一直都觉得太多内容了、太深入了 然后面试的时候不知道从哪里讲起、于是我写了这篇CSDN帮助大家面试回答、具体的深入解析下次再说 面试官你好 我来介绍一下Redis的五种基本数据类型 有String List Set ZSet Map 五种基…

关于类模板STL中vector容器的运用和智能指针的实现

代码题&#xff1a;使用vector实现一个简单的本地注册登录系统 注册&#xff1a;将账号密码存入vector里面&#xff0c;注意防重复判断 登录&#xff1a;判断登录的账号密码是否正确 #include <iostream> #include <cstring> #include <cstdlib> #in…

Opencv计算机视觉编程攻略-第十一节 三维重建

此处重点讨论在特定条件下&#xff0c;重建场景的三维结构和相机的三维姿态的一些应用实现。下面是完整投影公式最通用的表示方式。 在上述公式中&#xff0c;可以了解到&#xff0c;真实物体转为平面之后&#xff0c;s系数丢失了&#xff0c;因而无法会的三维坐标&#xff0c;…

git修改已经push的commit的message

1.修改信息 2.修改message 3.强推

2026考研数学张宇武忠祥复习视频课,高数基础班+讲义PDF

2026考研数学武忠祥老师课&#xff08;网盘&#xff09;&#xff1a;点击下方链接 2026考研数学武忠祥网课&#xff08;最新网盘&#xff09; 一、基础阶段&#xff08;3-5个月&#xff09; 目标&#xff1a;搭建知识框架掌握基础题型 教材使用&#xff1a; 高数&#xff1a;…

C++使用Qt Charts可视化大规模点集

引言 数据可视化是数据分析和决策过程中的重要环节。随着数据量的不断增长&#xff0c;如何高效地可视化大规模数据集成为了一个挑战。Qt Charts 提供了一个强大的工具集&#xff0c;用于创建直观的数据可视化图表。本文将探讨如何使用 C 和 Qt Charts 可视化大规模点集&#…

质检LIMS系统在生态修复企业的实践 生态修复行业的质量管控难题

一、生态修复行业的质量管控新命题 在生态文明建设的大背景下&#xff0c;生态修复企业面临着复杂的环境治理挑战。土壤改良、水体净化、植被恢复等工程&#xff0c;均需以精准的实验数据支撑决策。传统实验室管理模式存在数据孤岛、流程非标、合规风险高等痛点&#xff0c;而…

Spring Cloud之服务入口Gateway之Route Predicate Factories

目录 Route Predicate Factories Predicate 实现Predicate接口 测试运行 Predicate的其它实现方法 匿名内部类 lambda表达式 Predicate的其它方法 源码详解 代码示例 Route Predicate Factories The After Route Predicate Factory The Before Route Predicate Fac…

《AI大模型应知应会100篇》第6篇:预训练与微调:大模型的两阶段学习方式

第6篇&#xff1a;预训练与微调&#xff1a;大模型的两阶段学习方式 摘要 近年来&#xff0c;深度学习领域的一个重要范式转变是“预训练-微调”&#xff08;Pretrain-Finetune&#xff09;的学习方式。这种两阶段方法不仅显著提升了模型性能&#xff0c;还降低了特定任务对大…

java后端对时间进行格式处理

时间格式处理 通过java后端&#xff0c;使用jackson库的注解JsonFormat(pattern "yyyy-MM-dd HH:mm:ss")进行格式化 package com.weiyu.pojo;import com.fasterxml.jackson.annotation.JsonFormat; import lombok.AllArgsConstructor; import lombok.Data; import …

汽车BMS技术分享及其HIL测试方案

一、BMS技术简介 在全球碳中和目标的战略驱动下&#xff0c;新能源汽车产业正以指数级速度重塑交通出行格局。动力电池作为电动汽车的"心脏"&#xff0c;其性能与安全性不仅直接决定了车辆的续航里程、使用寿命等关键指标&#xff0c;更深刻影响着消费者对电动汽车的…

【TI MSPM0】CMSIS-DSP库学习

一、什么是CMSIS-DSP库 基于Cortex微控制器软件接口标准的数字信号处理的函数库 二、页面概览 这个用户手册用来描述CMSIS-DSP软件的函数库&#xff0c;有通用的计算处理函数给Cortex-M和Cortex-A的处理器使用 三、工程学习 1.导入工程 2.样例介绍 在Q15的格式下&#xff0c…

Vue3:初识Vue,Vite服务器别名及其代理配置

一、创建一个Vue3项目 创建Vue3项目默认使用Vite作为现代的构建工具&#xff0c;以下指令本质也是通过下载create-vue来构建项目。 基于NodeJs版本大于等于18.3&#xff0c;使用命令行进行操作。 1、命令执行 npm create vuelatest输入项目名称 2、选择附加功能 选择要包含的功…

Go语言类型捕获及内存大小判断

代码如下&#xff1a; 类型捕获可使用&#xff1a;reflect.TypeOf()&#xff0c;fmt.Printf在的%T。 内存大小判断&#xff1a;len()&#xff0c;unsafe.Sizeof。 package mainimport ("fmt""unsafe""reflect" )func main(){var i , j 1, 2f…

学透Spring Boot — 017. 处理静态文件

这是我的《学透Spring Boot》专栏的第17篇文章&#xff0c;了解更多内容请移步我的专栏&#xff1a; Postnull CSDN 学透 Spring Boot 目录 静态文件 静态文件的默认位置 通过配置文件配置路径 通过代码配置路径 静态文件的自动配置 总结 静态文件 以前的传统MVC的项目…