前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL || 结果排序--聚集函数讲解

MySQL || 结果排序--聚集函数讲解

作者头像
宁在春
发布2022-10-31 14:11:57
2.1K0
发布2022-10-31 14:11:57
举报
文章被收录于专栏:关于Java学习@宁在春

MySQL 结果排序-- 聚集函数

一、环境准备

代码语言:javascript
复制
CREATE TABLE `student`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '学号',
  `student_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '学生姓名',
  `sex` varchar(5) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '性别\r\n',
  `age` int(11) NULL DEFAULT NULL COMMENT '年龄',
  `result` double(10, 0) NULL DEFAULT NULL COMMENT '成绩',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

INSERT INTO `student` VALUES (1, '小王', '男', 18, 90);
INSERT INTO `student` VALUES (2, '小李', '女', 19, 80);
INSERT INTO `student` VALUES (3, '小明', '男', 20, 85);
INSERT INTO `student` VALUES (4, '小张', '男', 21, 87);

二、查询结果排序

平常应用比较多的就是筛选热度产品、或者微博热搜。

语法格式:

SELECT 字段名1… FROM 表名 ORDER BY 字段名1 [ASC | DESC ] ,字段名2 [ASC | DESC ]…;

字段名1 、2 是对查询结果排序的依据。 ASC 表示升序 DESC表示降序。 默认是ASC。

举个爪子:

代码语言:javascript
复制
SELECT * FROM  student ORDER BY  age DESC ;
·
·

当后面跟两个排序规则的时候,是第一个字段名相同的时候,才按照第二个字段名排序规则排序。

剩下自己摸索。

思考:

查找 age 降序 student_name 升序 该怎么写?

三、查询的分组与汇总

聚集函数

函数

作用

AVG()

返回某列的平均值 (平均值)

COUNT()

返回某列的行数 (统计)

MAX()

返回某列的最大值 (最大值)

MIN()

返回某列的最小值 (最小值)

SUM()

返回某列值之和(求和)

3.1、查一下 学生们平均年龄

代码语言:javascript
复制
select AVG(age) as "年龄"  from student;

3.2、查一下总人数是多少

代码语言:javascript
复制
select count(id) as "总人数" from student;

3.3、查一下每个年龄有多少人

代码语言:javascript
复制
select age, count(id) as "总人数" from student GROUP BY age;
在这里插入图片描述
在这里插入图片描述

3.4、查出最大年龄

代码语言:javascript
复制
select MAX(age) as "最大年龄" from student ;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dzr9FGai-1619187251369)(8mysql_结果排序_聚集函数.assets/image-20210423220055446.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dzr9FGai-1619187251369)(8mysql_结果排序_聚集函数.assets/image-20210423220055446.png)]

小于一样。

3.5、查询出男女各多少人

代码语言:javascript
复制
select sex ,count(*) AS "人数" from student GROUP BY sex;
#GROUP BY 是将结果按照 后面跟的字段名分组

3.6、查询成绩的总分的是多少

代码语言:javascript
复制
select sum(result) as "成绩总分" FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BcxPQPRB-1619187251372)(8mysql_结果排序_聚集函数.assets/image-20210423221101057.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BcxPQPRB-1619187251372)(8mysql_结果排序_聚集函数.assets/image-20210423221101057.png)]

自言自语

第一次摸鱼。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-04-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • MySQL 结果排序-- 聚集函数
  • 一、环境准备
  • 二、查询结果排序
  • 三、查询的分组与汇总
    • 3.1、查一下 学生们平均年龄
      • 3.2、查一下总人数是多少
        • 3.3、查一下每个年龄有多少人
          • 3.4、查出最大年龄
            • 3.5、查询出男女各多少人
              • 3.6、查询成绩的总分的是多少
                • 自言自语
                相关产品与服务
                云数据库 MySQL
                腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档