mySql数据库学习002-表数据查询操作
表数据查询操作
表数据如下:
id | name | age | gender | class | createdAt | updatedAt |
---|---|---|---|---|---|---|
1 | 张三 | 20 | 男 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
2 | 李四 | 19 | 女 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
3 | 王五 | 21 | 女 | 二班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
4 | 赵六 | 18 | 女 | 二班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
5 | 孙七 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
6 | 周八 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
7 | 张三丰 | 15 | 男 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
一、基础查询
select id, name from student
查询结果:
id | name |
---|---|
1 | 张三 |
2 | 李四 |
3 | 王五 |
4 | 赵六 |
5 | 孙七 |
6 | 周八 |
7 | 张三丰 |
注意:
- 关键词
select
后id
,name
为要查询的字段,使用*
表示查询所有字段;
二、where条件查询
select * from student where gender = '男'
查询结果:
id | name | age | gender | class | createdAt | updatedAt |
---|---|---|---|---|---|---|
1 | 张三 | 20 | 男 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
5 | 孙七 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
6 | 周八 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
7 | 张三丰 | 15 | 男 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
解释:
where
后表示查询条件;- 另外,
where
语句支持>
、>=
、<
、<=
、=
、!=
、and
、or
、not
、between ... and ...
、is null
、is not null
、in
、like
、
select * from student where gender = '女' and age > 20
select * from student where gender = '女' or age < 19
select * from student where age > 15 and age < 20
select * from student where age between 16 and 19
select * from student where class is null
select * from student where class is not null
select * from student where age in(18,19)
select * from student where name like '李%'
select * from student where name like '%六'
select * from student where name like '%三%'
三、排序
select * from student where gender = '男' order by age desc
查询结果:
id | name | age | gender | class | createdAt | updatedAt |
---|---|---|---|---|---|---|
1 | 张三 | 20 | 男 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
5 | 孙七 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
6 | 周八 | 19 | 男 | 三班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
7 | 张三丰 | 15 | 男 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
解释:
order by
为排序的关键词,其中age
为排序的字段名,desc
表示倒序排列,asc
表示正序排列;
四、分页查询
select * from student limit 3 offset 0
select * from student limit 0, 3
查询结果:
id | name | age | gender | class | createdAt | updatedAt |
---|---|---|---|---|---|---|
1 | 张三 | 20 | 男 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
2 | 李四 | 19 | 女 | 一班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
3 | 王五 | 21 | 女 | 二班 | 2024-04-08 09:15:09 | 2024-04-08 09:15:09 |
解释:
limit
表示分页大小,offset
表示偏移量;- 在不使用
offset
关键词时,limit
后第一个参数为偏移量,第二个参数为分页大小; 偏移量
通常需要根据前端传值的pageSize
,pageNum
计算得来;
五、聚合函数
select sum(age) sum_age from student
select avg(age) avg_age from student
select count(*) stu_count from student
select max(age) max_age from student
select min(age) min_age from student
查询结果:
sum_age |
---|
131 |
解释:
- 聚合函数需要传参,参数可以为
*
,或者数据表中的字段; - 另外,对于聚合函数的结果,可以设置
别名
,如sum_age
表示查询到数据的年龄和;
六、分组查询
select class, count(class) class_count from student group by class order by class_count desc
查询结果:
class | class_count |
---|---|
三班 | 2 |
一班 | 2 |
二班 | 2 |
Null | 0 |
解释:
- 其中
class
为分组字段,group by
为分组查询关键词,class_count
为别名; - 在对数据进行分组的时候,
select
后面必须是分组字段或者聚合函数;
七、having条件查询
select class, avg(age) avgAge from student group by class having avgAge > 19
查询结果:
class | avgAge |
---|---|
一班 | 19.5 |
二班 | 19.5 |
解释:
class
为分组字段,avg(age)
聚合函数求年龄平均值,group by
分组关键词,having
分组关键词,表示从返回的结果集中筛选平均年龄大于等于19的班级;- 注意:最好设置聚合函数结果的别名
avgAge
;
八、Q & A
- 什么是结果集?有什么特点?与表有什么区别与联系?
- 通过查询语句从数据表中查询出来的结果成为结果集;以表的形式呈现;结果集和查询的表不是同一张表,结果集来自数据表;结果集保存在内存中,而数据表保存在硬盘上;
- 什么是聚合函数?怎么使用聚合函数?
- 对表中的数据进行统计和计算,一般结合分组(GROUP BY)来使用,用于统计和计算分组数据
- COUNT() 计算查询数据的数据总量
- SUM() 计算查询结果中所有指定字段的和
- AVG() 计算查询结果中所有指定字段的平均值
- MAX() 求查询结果中指定字段的最大值
- MIN() 求查询结果中指定字段的最小值;
- having 与 where 的区别是什么?
where
是去数据表中查询符合条件的数据,返回结果集;having
是去数据集中查询符合条件的数据,可以对分组之后查询到的结果进行筛选;
相关文章:
mySql数据库学习002-表数据查询操作
表数据查询操作 表数据如下: idnameagegenderclasscreatedAtupdatedAt1张三20男一班2024-04-08 09:15:092024-04-08 09:15:092李四19女一班2024-04-08 09:15:092024-04-08 09:15:093王五21女二班2024-04-08 09:15:092024-04-08 09:15:094赵六18女二班2024-04-08 0…...

【STL】stack与queue的底层原理及其实现
文章目录 stack的介绍库中stack的使用栈的模拟实现queue的介绍库中queue的使用queue的模拟实现 stack的介绍 (图片来自知乎) 1.stack是一种容器适配器,模拟了栈的数据结构。数据只能从一端进去,另一端出来(先进后出&am…...
Ai大模型如何应用到机器视觉系统中
AI大模型在机器视觉系统中的应用可以通过以下几个步骤实现: 1. 数据准备与预处理: - 收集和标注大量高质量的图像数据,这些数据应该覆盖机器视觉系统需要处理的各种场景和对象。 - 对图像数据进行预处理,包括去噪、标准化、增强等…...
IntelliJ IDEA下载及安装教程(Windows操作系统)
一、下载IntelliJ IDEA 1、访问JetBrains官方网站 打开浏览器,输入网址 https://www.jetbrains.com/idea/ 进入IntelliJ IDEA官方主页。 2、选择产品版本 IntelliJ IDEA分为免费的Community Edition(社区版)和付费的Ultimate Edition&…...

01 Python进阶:正则表达式
re.match函数 使用 Python 中的 re 模块时,可以通过 re.match() 函数来尝试从字符串的开头匹配一个模式。以下是一个简单的详解和举例: import re# 定义一个正则表达式模式 pattern r^[a-z] # 匹配开头的小写字母序列# 要匹配的字符串 text "h…...
pdf图片识别分类
文章目录 解析pdf数据ocr识别分类方法正则匹配词频统计分类模型 分类完提示 解析pdf数据 试了几种方法 fitz-get_image后面方法不适用,用pixmap分辨率低 用pypdf2版本低方法用不了 用pdf2image还要下依赖工具 用spire.pdf的SaveAsImage分辨率低,Extract…...
24双非考研哈尔滨工程大学计算机(@程程笔记)
前言 个人情况,本科双非考研软件工程。24考研成绩总分369(政治75,英语58,数学102,专业课134),整体各科成绩比较均衡,没有太突出和瘸腿的,初始排名5/19,复试后排名5/13。 政治 政治…...

IO流(2.其他流)
能够高效读写的缓冲流,能够转换编码的转换流,能够持久化存储对象的序列化流 一、缓冲流 缓冲流,也叫高效流,是对4个基本的FileXxx 流的增强,所以也是4个流,按照数据类型分类: 字节缓冲流:Buffe…...

PyTorch之计算模型推理时间
一、参考资料 如何测试模型的推理速度 Pytorch 测试模型的推理速度 二、计算PyTorch模型推理时间 1. 计算CPU推理时间 import torch import torchvision import time import tqdm from torchsummary import summarydef calcCPUTime():model torchvision.models.resnet18()…...

layui后台框架,将左侧功能栏目 集中到一个页面,通过上面的tab切换 在iframe加载对应页面
实现上面的 功能效果。 1 html代码 <form class"layui-form layui-form-pane" action""><div class"layui-tab" lay-filter"demo"><ul class"layui-tab-title"><li id"a0" class"lay…...

【网络原理】使用Java基于TCP搭建简单客户端与服务器通信
目录 🎄API介绍🌸ServerSocket API🌸Socket API 🍀TCP中的长短连接🌳建立TCP回显客户端与服务器🌸TCP搭建服务器🌸TCP搭建客户端 ⭕总结 TCP服务器与客户端的搭建需要借助以下API 🎄…...
Hadoop生态系统主要是什么?
Hadoop生态系统主要由以下几部分组成: Hadoop HDFS:这是Hadoop的核心组件之一,是一个用于存储大数据的分布式文件系统。它可以在廉价的硬件上提供高度的容错性,通过数据复制和故障切换实现数据的高可用性。 MapReduce:…...

GlusterFS分布式文件系统
前言 存储可分为文件存储和对象存储,常见的文件存储相关技术有:nfs、lvm、raid;常见的对象存储相关技术有:gfs、ceph、fdfs、nas、oss、s3、switch。GlusterFS 归类为文件存储系统,它提供了一种强大的方式来管理和存储…...

spark本地模拟多个task时如何启动多个Excutor
1、首先在9090端口下启动Excutor,作为第一个Excutor 2、然后修改9090端口为:9091,如下图点击Edit Configration 3、然后按下图操作 , 4、修改一下名字 5、点击apply,🆗 6、检查下面圈1是否是刚刚我们新建的MyExcutor(2…...
RocketMQ笔记(八)SpringBoot整合RocketMQ广播消费消息
目录 一、简介1.1、消费模式 二、消费者2.1、maven依赖2.2、application配置2.3、消费监听 三、生产者3.1、发送消息3.2、运行结果 四、其他 一、简介 在之前的文章中,我们讲过了,同步发送单条消息,异步发送单条消息,发送单向消息…...

Appium如何自动判断浏览器驱动
问题:有的测试机chrome是这个版本,有的是另一个版本,怎么能让自动判断去跑呢?? 解决办法:使用appium的chromedriverExecutableDir和chromedriverChromeMappingFile 切忌使用chromedriverExecutableDir和c…...
MVCC-多版本并发控制
MVCC(多版本并发控制)简介 在数据库系统中,并发控制是一个非常重要的话题。为了提高系统的并发性能和吞吐量,现代数据库系统通常使用多种技术来实现对数据的安全访问,其中一种重要的技术就是多版本并发控制࿰…...
c++找最高成绩
根据给定的程序,写成相关的成员函数,完成指定功能。 函数接口定义: 定义max函数,实现输出最高成绩对应的学号以及最高成绩值。 裁判测试程序样例: #include <iostream> using namespace std; class Student{…...
前端saas化部署
在项目中难免会遇到一些特殊的需求,例如同一套代码需要同时部署上两个不同的域名A和B。A和B的不同之处仅在于,例如一些背景图片,logo,展示模块的不同,其他业务逻辑是和展示模块是完全一样的。此时我们当然可以考虑单独…...

[Java基础揉碎]Math类
目录 基本介绍 方法一览(均为静态方法) 1) abs 绝对值 2) pow 求幂 3) ceil 向上取整 4) floor 向下取整 5) round 四舍五入 6) sqrt 求开方 7) random求随机数 8) max 求两个数的最大值 9) min 求两个数的最小值 基本介绍 Math类包含用于执行基本数学运算的方法&…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度
一、引言:多云环境的技术复杂性本质 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,基础设施的技术债呈现指数级积累。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
Robots.txt 文件
什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...

ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...

SpringCloudGateway 自定义局部过滤器
场景: 将所有请求转化为同一路径请求(方便穿网配置)在请求头内标识原来路径,然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...
高防服务器能够抵御哪些网络攻击呢?
高防服务器作为一种有着高度防御能力的服务器,可以帮助网站应对分布式拒绝服务攻击,有效识别和清理一些恶意的网络流量,为用户提供安全且稳定的网络环境,那么,高防服务器一般都可以抵御哪些网络攻击呢?下面…...
MinIO Docker 部署:仅开放一个端口
MinIO Docker 部署:仅开放一个端口 在实际的服务器部署中,出于安全和管理的考虑,我们可能只能开放一个端口。MinIO 是一个高性能的对象存储服务,支持 Docker 部署,但默认情况下它需要两个端口:一个是 API 端口(用于存储和访问数据),另一个是控制台端口(用于管理界面…...

使用SSE解决获取状态不一致问题
使用SSE解决获取状态不一致问题 1. 问题描述2. SSE介绍2.1 SSE 的工作原理2.2 SSE 的事件格式规范2.3 SSE与其他技术对比2.4 SSE 的优缺点 3. 实战代码 1. 问题描述 目前做的一个功能是上传多个文件,这个上传文件是整体功能的一部分,文件在上传的过程中…...

倒装芯片凸点成型工艺
UBM(Under Bump Metallization)与Bump(焊球)形成工艺流程。我们可以将整张流程图分为三大阶段来理解: 🔧 一、UBM(Under Bump Metallization)工艺流程(黄色区域ÿ…...

Java后端检查空条件查询
通过抛出运行异常:throw new RuntimeException("请输入查询条件!");BranchWarehouseServiceImpl.java // 查询试剂交易(入库/出库)记录Overridepublic List<BranchWarehouseTransactions> queryForReagent(Branch…...