当前位置: 首页 > news >正文

mySql数据库学习002-表数据查询操作

表数据查询操作

表数据如下:

idnameagegenderclasscreatedAtupdatedAt
1张三20一班2024-04-08 09:15:092024-04-08 09:15:09
2李四19一班2024-04-08 09:15:092024-04-08 09:15:09
3王五21二班2024-04-08 09:15:092024-04-08 09:15:09
4赵六18二班2024-04-08 09:15:092024-04-08 09:15:09
5孙七19三班2024-04-08 09:15:092024-04-08 09:15:09
6周八19三班2024-04-08 09:15:092024-04-08 09:15:09
7张三丰152024-04-08 09:15:092024-04-08 09:15:09
一、基础查询
select id, name from student

查询结果

idname
1张三
2李四
3王五
4赵六
5孙七
6周八
7张三丰

注意

  • 关键词 selectid,name为要查询的字段,使用 * 表示查询所有字段;

二、where条件查询
select * from student where gender = '男'

查询结果

idnameagegenderclasscreatedAtupdatedAt
1张三20一班2024-04-08 09:15:092024-04-08 09:15:09
5孙七19三班2024-04-08 09:15:092024-04-08 09:15:09
6周八19三班2024-04-08 09:15:092024-04-08 09:15:09
7张三丰152024-04-08 09:15:092024-04-08 09:15:09

解释

  • where 后表示查询条件;
  • 另外,where 语句支持 >>=<<==!=andornotbetween ... and ...is nullis not nullinlike
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

查询结果

idnameagegenderclasscreatedAtupdatedAt
1张三20一班2024-04-08 09:15:092024-04-08 09:15:09
5孙七19三班2024-04-08 09:15:092024-04-08 09:15:09
6周八19三班2024-04-08 09:15:092024-04-08 09:15:09
7张三丰152024-04-08 09:15:092024-04-08 09:15:09

解释:

  • order by 为排序的关键词,其中 age 为排序的字段名,desc 表示倒序排列,asc表示正序排列;

四、分页查询
select * from student limit 3 offset 0
select * from student limit 0, 3

查询结果

idnameagegenderclasscreatedAtupdatedAt
1张三20一班2024-04-08 09:15:092024-04-08 09:15:09
2李四19一班2024-04-08 09:15:092024-04-08 09:15:09
3王五21二班2024-04-08 09:15:092024-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

查询结果:

classclass_count
三班2
一班2
二班2
Null0

解释:

  • 其中 class 为分组字段,group by 为分组查询关键词,class_count为别名;
  • 在对数据进行分组的时候,select 后面必须是分组字段或者聚合函数;

七、having条件查询
select class, avg(age) avgAge from student group by class having avgAge > 19

查询结果:

classavgAge
一班19.5
二班19.5

解释:

  • class 为分组字段,avg(age) 聚合函数求年龄平均值,group by 分组关键词,having 分组关键词,表示从返回的结果集中筛选平均年龄大于等于19的班级;
  • 注意:最好设置聚合函数结果的别名avgAge

八、Q & A
  1. 什么是结果集?有什么特点?与表有什么区别与联系?
  • 通过查询语句从数据表中查询出来的结果成为结果集;以表的形式呈现;结果集和查询的表不是同一张表,结果集来自数据表;结果集保存在内存中,而数据表保存在硬盘上;
  1. 什么是聚合函数?怎么使用聚合函数?
  • 对表中的数据进行统计和计算,一般结合分组(GROUP BY)来使用,用于统计和计算分组数据
  • COUNT() 计算查询数据的数据总量
  • SUM() 计算查询结果中所有指定字段的和
  • AVG() 计算查询结果中所有指定字段的平均值
  • MAX() 求查询结果中指定字段的最大值
  • MIN() 求查询结果中指定字段的最小值;
  1. having 与 where 的区别是什么?
  • where 是去数据表中查询符合条件的数据,返回结果集;
  • having 是去数据集中查询符合条件的数据,可以对分组之后查询到的结果进行筛选;
http://www.lryc.cn/news/335061.html

相关文章:

  • 【STL】stack与queue的底层原理及其实现
  • Ai大模型如何应用到机器视觉系统中
  • IntelliJ IDEA下载及安装教程(Windows操作系统)
  • 01 Python进阶:正则表达式
  • pdf图片识别分类
  • 24双非考研哈尔滨工程大学计算机(@程程笔记)
  • IO流(2.其他流)
  • PyTorch之计算模型推理时间
  • layui后台框架,将左侧功能栏目 集中到一个页面,通过上面的tab切换 在iframe加载对应页面
  • 【网络原理】使用Java基于TCP搭建简单客户端与服务器通信
  • Hadoop生态系统主要是什么?
  • GlusterFS分布式文件系统
  • spark本地模拟多个task时如何启动多个Excutor
  • RocketMQ笔记(八)SpringBoot整合RocketMQ广播消费消息
  • Appium如何自动判断浏览器驱动
  • MVCC-多版本并发控制
  • c++找最高成绩
  • 前端saas化部署
  • [Java基础揉碎]Math类
  • MyBatis输入映射
  • 金三银四,程序员求职季
  • [react优化] 避免组件或数据多次渲染/计算
  • 「意」起出发 丨意大利OXO城市展厅盛大启幕,成都设计圈共襄盛举
  • 你不知道的JavaScript---深入理解 JavaScript 作用域
  • FPGA(Verilog)实现按键消抖
  • 第十二届蓝桥杯大赛软件赛省赛C/C++大学B组
  • 面了钉钉搜广增算法岗(暑期实习),秒挂。。。。
  • 前端实现流文件下载的完整指南
  • Kotlin:常用标准库函数(let、run、with、apply、also)
  • 雷军给年轻人的五点建议