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类包含用于执行基本数学运算的方法&…...

MyBatis输入映射
1 parameterType parameterType:接口中方法参数的类型,类型必须是完全限定名或别名(稍后讲别名)。该属性非必须,因为Mybatis框架能自行判断具体传入语句的参数,默认值为未设置(unset)。<sel…...

金三银四,程序员求职季
随着春天的脚步渐近,对于许多程序员来说,一年中最繁忙、最重要的面试季节也随之而来。金三银四,即三月和四月,被广大程序员视为求职的黄金时期。在这两个月里,各大公司纷纷开放招聘,求职者们则通过一轮又一…...

[react优化] 避免组件或数据多次渲染/计算
代码如下 点击视图x➕1,导致视图更新, 视图更细导致a也重新大量计算!!这很浪费时间 function App() {const [x, setX] useState(3)const y x 2console.log(重新渲染, x, y);console.time(timer)let a 0for (let index 0; index < 1000000000; index) {a}console.timeE…...

「意」起出发 丨意大利OXO城市展厅盛大启幕,成都设计圈共襄盛举
4月8日,主题为“「意」起出发「智」见OXO”的意大利OXO城市展厅发布会在成都大悦城OXO成都城市展厅隆重举办。 大会现场,成都装饰协会领导,喜尔康董事长吴锡山,天合智能副董事长罗洁,意大利OXO卫浴市场部总监兰彬&…...

你不知道的JavaScript---深入理解 JavaScript 作用域
你好,我是小白Coding日志,一个热爱技术的程序员。在这里,我分享自己在编程和技术世界中的学习心得和体会。希望我的文章能够给你带来一些灵感和帮助。欢迎来到我的博客,一起在技术的世界里探索前行吧! 1. 什么是作用域…...

FPGA(Verilog)实现按键消抖
实现按键消抖功能: 1.滤除按键按下时的噪声和松开时的噪声信号。 2.获取已消抖的按键按下的标志信号。 3.实现已消抖的按键的连续功能。 Verilog实现 模块端口 key_filter(input wire clk ,input wire rst_n ,input wire key_in , //按下按键时为0output …...

第十二届蓝桥杯大赛软件赛省赛C/C++大学B组
第十二届蓝桥杯大赛软件赛省赛C/C 大学 B 组 文章目录 第十二届蓝桥杯大赛软件赛省赛C/C 大学 B 组1、空间2、卡片3、直线4、货物摆放5、路径6、时间显示7、砝码称重8、杨辉三角形9、双向排序10、括号序列 1、空间 1MB 1024KB 1KB 1024byte 1byte8bit // cout<<"2…...

面了钉钉搜广增算法岗(暑期实习),秒挂。。。。
节前,我们星球组织了一场算法岗技术&面试讨论会,邀请了一些互联网大厂朋友、参加社招和校招面试的同学,针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 汇总…...

前端实现流文件下载的完整指南
在现代Web开发中,经常会遇到需要从服务器下载文件的情况。有时候这些文件是事先存储好的,可以通过简单的URL链接直接下载;但有时候,我们需要从数据流中动态生成文件并将其提供给用户。本篇博客将介绍如何在前端实现流文件下载的完…...

Kotlin:常用标准库函数(let、run、with、apply、also)
一、let 扩展函数 Kotlin标准库函数let可用于范围确定和空检查。当调用对象时,let执行给定的代码块并返回其最后一个表达式的结果。对象可以通过引用(默认情况下)或自定义名称在块中访问。 let扩展函数源码 let.kt文件代码 fun main() {println("isEmpty $is…...