6. MySQL基本查询
1. 表的增删改查
2. Create & Insert
2.1. 案例: 创建一个学生表
3. 插入替换
3.1. on duplicate: 语句1 on duplicate 语句2
- 1 row affected: 表中没有冲突数据, 数据被插入
- 2 row affected: 表中存在冲突数据, 数据被更新
- 0 row affected: 表中有冲突数据, 且冲突数据的值和update的值相等(update执行失败)
3.2. replace: replace 语句1
- 1 row affected: 表中没有冲突数据, 数据被插入
- 2 row affected: 表中存在冲突数据, 删除后重新插入
4. 基本select指令(查询)
4.1. 全列查询
- 指定一/多列查询 select id, math from table_name
- select 后可以跟表达式 select math+chinese+english from table_name(计算总成绩)
- select 可以对表达式重命名 select math+chinese+english as(可省略) total from table_name(计算总成绩)
- select 支持去重 select distinct math from table_name
5. where子句 判断条件(过滤条件)
- >, >=, <, <=
- = 注: null不安全
- <=>注: null安全
- != 注: null不安全
- <>
- between a0 and a1 范围匹配
- in (option...)
- is null
- is not null
- like(% _) 模糊匹配
- and or not
5.1. 知识点: select * from table_name where 语句的执行顺序(⭐⭐⭐)

- 明确从哪个数据表中拿数据 from table_name
- 其次看要筛选哪些条件 where 语句
- 最后进行显示 select *
5.2. 案例
- 案例1: 找出成绩单中英语不及格(<60)的人的姓名 以及 对应的英语成绩
- 案例2: 语文成绩在[80, 90]区间的同学的姓名 + 对应的语文成绩
- 案例3: 数学成绩在58 || 59 || 98 || 99分的同学姓名 + 成绩
- 案例4: 找一下成绩单中姓孙的同学
- 案例5: 语文成绩好于英语成绩的同学
- 案例6: 总分在200分以下的同学
- 案例7: 语文成绩>80分 并且 不姓孙的同学
- 案例8: 孙某同学,否则要求总成绩>200 并且 语文成绩<数学成绩 并且 英语成绩>80
- 案例9: null的查询
- name is null
- "" 与 null区分
- 查询不为空
6. order by子句(排序指令)
- asc 升序(默认)
- desc 降序
6.1. 执行顺序: select ... from table_name where ... order by ...

- FROM:先确定表的来源,并且进行表连接操作(要是有多个表的话)。
- WHERE:对 FROM 子句产生的记录进行过滤,筛选出符合条件的记录。
- GROUP BY:按照指定的列对记录进行分组。
- HAVING:对分组后的结果进行过滤。
- SELECT:从符合条件的记录中选择需要返回的列。
- ORDER BY:对查询结果按照指定的列进行排序。
- LIMIT/OFFSET:限制返回记录的数量或者跳过前面的若干条记录。
6.2. 案例
- 案例1: 同学及数学成绩, 按照升序显示
- 案例2: 同学以及qq号进行排序
- 案例3: 依次查询同学们的各科成绩, 如果有相等的, 按照数学降序, 语文降序, 英语升序的排序进行类推排序显示
- 案例4: 查询同学的总分, 从高到低查询显示
- 案例5: 查询姓孙或姓曹的同学, 结果按照数学成绩从高到低进行显示(降序)
7. limit 子句(显示分页)

8. update
8.1. 案例
- 案例1: 把孙悟空同学的数学成绩变更为80分
- 案例2: 将曹孟德同学的数学成绩变更为60分, 语文成绩变更为70分
- 案例3: 将总成绩倒数前三的三位同学, 数学成绩 += 30分
- 确定目标表:明确要更新的表是 student。
- 生成待更新记录集合:对 student 表的所有记录按 math + chinese + english 的总分升序排序,取前 3 条记录形成临时待更新集合。
- 执行更新操作:对临时集合中的每条记录,将其 math 列的值增加 30。
- 要点:
-
- 排序与限制的作用:ORDER BY 和 LIMIT 这两个子句是在确定最终要更新哪些记录时发挥作用的,而不是在更新操作执行之后才起作用。
- 更新的原子性:一旦确定了要更新的 3 条记录,更新操作就会按照这 3 条记录原本的顺序依次执行。即便在更新过程中某些记录的总分发生了变化,也不会影响后续其他记录的更新。
- 与 SELECT 执行顺序的差异:UPDATE 语句不存在 SELECT 语句里那种先投影列(SELECT 子句)再排序的过程。在 UPDATE 中,排序是直接基于原始表的数据进行的。
- 案例4: 将所有同学的语文成绩更新为原来的两倍
- 没有筛选条件的时候, 直接是做整表的更新
9. delete
9.1. 案例
- 案例1: 删除孙悟空的考试成绩
- 案例2: 删除班级里总成绩倒数第一的人
- 案例3: 删除整张表(内容)
-
-
- delete from test_table(删除整表)
-
- truncate
- 只能对整表使用, 不能像delete一样针对部分数据操作
- 实际上mysql不对数据操作, 所以比delete更快, 但是在删除数据的时候不经过真正的事务, 因此不能回滚.
- 会重置 auto_increment
10. 去重表数据
11. 聚合统计
- COUNT([DISTINCT] expr) 返回查询到的数据的 数量
- SUM([DISTINCT] expr) 返回查询到的数据的 总和,不是数字没有意义
- AVG([DISTINCT] expr) 返回查询到的数据的 平均值,不是数字没有意义
- MAX([DISTINCT] expr) 返回查询到的数据的 最大值,不是数字没有意义
- MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义
11.1. 案例:
- 案例1: 统计班级共有多少同学 (注: 使用表达式统计随便写一个数字也可以)
- 案例2: 统计班级收集的 qq 号有多少
- 案例3: 统计本次考试的数学成绩分数个数
- 案例4: 统计数学成绩总分
- 案例5: 统计平均总分
- 案例6: 返回英语最高分
- 不同的数据类型无法聚合
- 案例7: 返回 > 70 分以上的数学最低分
12. 分组聚合统计
12.1. 案例:
- 案例1: 如何显示每个部门的平均工资和最高工资
- 案例2: 显示每个部门的每种岗位的平均工资和最低工资
- 案例3: 显示平均工资低于2000的部门和它的平均工资
- 统计各个部门的平均工资
- having和group by配合使用,对group by结果进行过滤
相关文章:

6. MySQL基本查询
1. 表的增删改查 Create(创建), Retrieve(读取), Update(更新), Delete(删除) 2. Create & Insert 语法: insert [info] table_name () values () 2.1. 案例: 创建一个学生表 指定列单行插入, 如果values前省略, 则默认是全属性插入多行指定列插入, 中间分隔符为, 3. 插入替…...
JavaWeb简介
目录 1.1 JavaWeb 简介 1.2 JavaWeb 技术栈 1.3 JavaWeb 交互模式 1.4 JavaWeb 的 C/S 和 B/S 模式 C/S 模式 (Client-Server / 客户端-服务器模式) B/S 模式 (Browser-Server / 浏览器-服务器模式) 1.5 JavaWeb 实现前…...

CMS32M65xx/67xx系列CoreMark跑分测试
CMS32M65xx/67xx系列CoreMark跑分测试 1、参考资料准备 1.1、STM32官方跑分链接 1.2、官网链接 官方移植文档,如下所示,点击红框处-移植文档: A new whitepaper and video explain how to port CoreMark-Pro to bare-metal 1.3、测试软件git下载链接 …...

中国区域30m/15天植被覆盖度数据集(2010-2022)
时间分辨率:日空间分辨率;:10m - 100m共享方:式开放获取数据大小:2.98 TB数据时间范围:2010-01-01 — 2022-12-31元数据更新时间:2024-12-23 数据集摘要 高时空分辨率的植被覆盖度产品存在着广…...
LabVIEW准分子激光器智能控制系统
LabVIEW 开发准分子激光器智能控制系统,针对放电激励型准分子激光器强电磁干扰环境下的控制难题,采用 “PC 端 LabVIEW 人机交互 MCU 端实时控制 光纤隔离通信” 架构,实现激光能量闭环控制、腔体环境监测、气路自动管理等功能。硬件选用 N…...
微服务面试资料1
在当今快速发展的技术领域,微服务架构已经成为构建复杂系统的重要方式之一。本文将围绕微服务的核心概念、技术栈、分布式事务处理、微服务拆分与设计,以及敏捷开发实践等关键问题展开深入探讨,旨在为准备面试的 Java 开发者提供一份全面的复…...
Pytest Fixture 详解
Pytest Fixture 详解 Fixture 是 pytest 最强大的功能之一,用于提供测试所需的依赖资源(如数据库连接、临时文件、模拟对象等),并支持复用、作用域控制和自动清理。以下是全面详解: 1. 基本用法 定义 Fixture 使用 …...

力扣HOT100之二分查找:74. 搜索二维矩阵
这道题直接a了,我们可以参考上一道题:35.搜索插入位置的思路,详情见我的上一篇博客。将每一行的第一个元素当作一个数组中的元素,然后对这个数组进行二分查找,如果直接找到了target,则直接返回true…...
【前端】前后端通信
前端开发主要完成的两件事: 1)界面搭建 2)数据交互 本知识页参考: https://juejin.cn/post/6925296067378429960 0. XMLHttpRequest 客户端的一个API,为浏览器和服务器通信提供了一个便携通道。现代浏览器支持XMLHttp…...

编程技能:格式化打印04,sprintf
专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏,故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 (一)WIn32 专栏导航 上一篇:编程技能:格式化打印03,printf 回到目录…...
C语言基础(11)【函数1】
内容提要 函数 文章目录 内容提要函数函数的描述函数的分类相关概念函数的定义:定义:案例: 形参和实参形参(形式参数)实参(实际参数)案例: 函数的返回值案例: 函数 函数…...

R语言基础| 下载、安装
在此前的单细胞教程中,许多小伙伴都曾因为R语言基础不足而十分苦恼。R语言是一种开源的编程语言和软件环境,专门用于统计分析、图形表示和数据挖掘。它最初由Ross Ihaka和Robert Gentleman在1993年创建,旨在为统计学家和数据分析师提供一个广…...
【hive sql】窗口函数
参考 包括窗口函数在内的执行顺序 from & join --确定数据源 where --行级过滤 group by --分组 having --组级过滤 窗口函数 --计算窗口函数结果 select --选择列 distinct --去重 order by --最终排序(可对窗口函数结果进行排序) limit/offset -…...
Ubuntu24.04 交叉编译 aarch64 ffmpeg
ffmpeg 官网: https://ffmpeg.org文档: https://ffmpeg.org/documentation.html 编译参数说明: https://trac.ffmpeg.org/wiki/CompilationGuide/Generic在Linux下编译: https://trac.ffmpeg.org/wiki/CompilationGuide 下载页: https://ffmpeg.org/download.html 安装依赖 …...
《AI角色扮演反诈技术解析:原理、架构与核心挑战》
AI角色扮演反诈技术解析:原理、架构与核心挑战 研究目标 技术栈梳理: 系统总结AI角色扮演在执法场景中的实现路径,涵盖大型语言模型(LLM)、提示词工程(Prompt Engineering)、多模态交互链路等…...

微软的新系统Windows12未来有哪些新特性
在今年即将到来的重大设计升级中,苹果计划对其全线操作系统统一按年份命名,作为另一巨头微软的win12还远吗?win11和win10是微软现在正在用的主流版本,win11系统发布于2021年6月24日,win10系统发布于2015年7月29日。预计win12尝鲜版可能在2025年下半年或明年。 尽管win12还…...
树莓派超全系列教程文档--(54)如何使用rsync在计算机之间同步文件夹
如何使用rsync在计算机之间同步文件夹 使用 rsync 在计算机之间同步文件夹 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 使用 rsync 在计算机之间同步文件夹 您可以使用 rsync 在计算机之间同步文件夹。例如,您可以使用 rsync 将R…...
华为ICT和AI智能应用
在华为的业务布局中,AI智能创新则贯穿于华为多个业务领域,二者紧密相关,共同推动华为及相关行业的发展。以下是具体介绍: Techco转型 - 背景:随着5G - A、云、人工智能等技术的发展,运营商从传统连接服…...
ROS2与Unitree机器人集成指南
Tested systems and ROS2 distro systemsROS2 distroUbuntu 20.04foxyUbuntu 22.04humblesrc目录上级才可以colcon build git clone https://github.com/unitreerobotics/unitree_ros2 Install Unitree ROS2 package 1. Dependencies sudo apt install ros-humble-rmw-cyclon…...

在虚拟宇宙中低语——进程间通信,Linux命名管道的前世今生
文章目录 🌌 序章🌠 一、命名管道的宿命与哲学1.1、创建及简单使用1.2、命名管道的工作原理1.3、命名管道与匿名管道的区别 2、命名管道的特点及特殊场景2.1、特点2.2、四种特殊场景 3、命名管道实操3.1、实现文件拷贝3.2、实现进程控制 小结 dz…...
Cursor 工具项目构建指南:Java 21 环境下的 Spring Boot Prompt Rules 约束
简简单单 Online zuozuo: 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo : 文章目录 Cursor 工具项目构建指南:Java 21 环境下的 Spring Boot Prompt Rules 约束前言项目简…...
各个布局的区别以及示例
各个布局的区别以及示例 在前端开发中,常见的布局方式主要有以下几种,每种布局都有其适用场景和特点: 1. 普通文档流(Normal Flow) 特点:默认布局方式,元素按照HTML顺序依次排列。适用场景&am…...
什么是MVC?
导语: 在Java后端面试中,“MVC架构”是绕不开的基础话题。它不仅关乎项目的整体设计思路,更体现了候选人的架构理解能力与编码规范意识。本文将从面试官视角出发,结合高频问题、代码示例、答题技巧与加分项,带你全面吃…...

STM32的ADC简介
一、ADC简介 STM32的ADC是一种12位逐次逼近型模拟数字转换器。它具备18个通道,能够测量16个外部信号源以及2个内部信号源。各通道的A/D转换可以执行单次、连续、扫描或间断模式。转换结果可采用左对齐或右对齐的方式(12位)存储于16位数据寄存…...

Bash shell四则运算
文章目录 四则运算1. expr 命令2. $(( )) 表达式(推荐)3. $[ ] 表达式(已弃用)4. let 命令小数运算i 和 i 区别 四则运算 算术运算: - * / %(取模,求余数) Bash sh…...

(javaSE)Java数组进阶:数组初始化 数组访问 数组中的jvm 空指针异常
数组的基础 什么是数组呢? 数组指的是一种容器,可以用来存储同种数据类型的多个值 数组的初始化 初始化:就是在内存中,为数组容器开辟空间,并将数据存入容器中的过程。 数组初始化的两种方式:静态初始化,动态初始化 数组的静态初始化 初始化…...

力扣刷题Day 70:在排序数组中查找元素的第一个和最后一个位置(34)
1.题目描述 2.思路 方法1(自己写的):一次二分查找找到等于target的一个元素索引axis,然后向左右延伸找边界。 方法2(灵茶山艾府佬的闭区间二分查找写法):定义一个lower_bound()函数找到第一个…...
vue 多端适配之pxtorem
在 Vue 3 Vite 项目中使用 postcss-pxtorem 自动将 px 单位转换为 rem 单位,可以按照以下步骤配置: 一、基础版本 1. 安装依赖 首先安装必要的插件: npm install postcss postcss-pxtorem autoprefixer -D # 或 yarn add postcss postcs…...

图片压缩工具 | 图片属性详解及读取解析元数据
ℹ️ 图片信息及属性 基本属性 格式类型:JPEG、PNG、GIF、WEBP、BMP、TIFF等文件大小:以KB、MB等为单位的存储空间占用创建/修改日期:文件的元数据时间戳 视觉属性 尺寸/分辨率 宽度(像素)高度(像素&…...
React---day8
9.6 不可变数据的力量 我们知道是不能够修改this.state里面的数据的 举个例子 export class App extends React.PureComponent{constructor(){super();this.state {userList:[{name : "tom" , age : 18},{name : "lily" , age : 20},{name : "tik…...