首页 > 数据库 >sql处理重复的列,更好理清分组和分区

sql处理重复的列,更好理清分组和分区

时间:2023-03-11 20:13:27浏览次数:47  
标签:分区 score 分组 理清 student sql VALUES INTO


一、分组统计、分区排名

1、语法和含义:

如果查询结果看得有疑惑,看第二部分-sql处理重复的列,更好理清分组和分区,有建表插入数据的sql语句


分组统计:GROUP BY 结合 统计/聚合函数一起使用

-- 举例子: 按照性别统计男生、女生的人数
select sex,count(distinct id) sex_num from student_score group by sex;

分区排名:ROW_NUMBER() OVER(PARTITION BY 分区的字段 ORDER BY 升序/降序字段 [DESC])

-- 举例子: 按照性别-男生、女生进行分区,按照成绩进行降序
select id,name,sex,score,
ROW_NUMBER() OVER(PARTITION BY sex ORDER BY score DESC) rn
from student_score;


2、使用注意事项:

▷ 排名函数row_number() 需要的mysql 版本需要8及以上!

▷ 对于分组统计 group by 容易出现的报错问题:

因为规定要求 select 列表的字段非聚合字段,必须出现在group by后面进行分组

报错:Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column '数据库.表.字段' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

SELECT列表的表达式-不在GROUP BY子句中,并且包含非聚合列'数据库.表.字段'。

▷ 对于排名函数ROW_NUMBER,容易出现的报错问题:

  • 一般是你的分区字段写得有问题,可以坚持一下分区字段!比如在hive中,分区字段为 get_json_object(map_col,'$.title'),但是漏掉了一个'

报错:Failed to breakup Windowing invocations into Groups. At least 1 group must only depend on input columns. Also check for circular dependencies.

未能将窗口调用分解为组。至少 1 个组必须仅依赖于输入列。还要检查循环依赖。



二、sql处理重复的列,更好理清分组和分区

1、sql语句-建表、插入数据的语句

DROP TABLE IF EXISTS `student_score`;
CREATE TABLE `student_score` (
  `id`  int(6),
  `name` varchar(255),
  `sex` varchar(255),
  `subject` varchar(30),
  `score` float
) ENGINE = InnoDB;


INSERT INTO `student_score` VALUES (1, '小明', '男','语文', 80);
INSERT INTO `student_score` VALUES (2, '小红', '女','语文', 70);
INSERT INTO `student_score` VALUES (3, '小哈', '女','语文', 88);
INSERT INTO `student_score` VALUES (1, '小明', '男','数学', 66);
INSERT INTO `student_score` VALUES (2, '小红', '女','数学', 70);
INSERT INTO `student_score` VALUES (3, '小哈', '女','数学', 89);
INSERT INTO `student_score` VALUES (1, '小明', '男','英语', 80);
INSERT INTO `student_score` VALUES (2, '小红', '女','英语', 70);
INSERT INTO `student_score` VALUES (3, '小哈', '女','英语', 68);

2、查询所有学生的成绩:

  • select * from student_score;


3、结果,有重复的列值

相应的成绩对应的学科名称是以列的形式展示的,造成了语文、语文、语文的重复


4-1、处理重复的列-方式1-合并去除重复的列值[列转行]

对应到常见的sql应用场景,统计各个学生的各科成绩,实现方式有两种,一种是分组统计的方式,一种是分区排名的方式

分组统计:

select id,name,sex,
	max(case when subject='语文' then score else 0 end) as chinese,
	max(case when subject='英语' then score else 0 end) as english,
	max(case when subject='数学' then score else 0 end) as math
from student_score 
group by id
order by score desc
  • 结果:

按成绩降序排序,可以看到默认选择第一门学科-语文的成绩进行降序排序。


4-2、处理重复的列-方式2-对重复的列值进行排名

分区排名

select id,name,subject,score,
       row_number() over(partition by subject order by score desc) rn
from student_score;



三、总结分组、分区的区别

例如按学科分组或按学科分区,那么,分组得到的是一个列值(一条记录数据)的结果,分区是多个列值(多条记录数据)的结果。

分组-一条记录

分区-多条记录




如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

标签:分区,score,分组,理清,student,sql,VALUES,INTO
From: https://www.cnblogs.com/shan333/p/17206824.html

相关文章

  • delphi7连接mysql
    Params设置如下:相关控件按如下顺序连接 ......
  • PentestLab-web安全SQL注入-EXP2
    我们打开pentestlab靶机选择“sql  injections”选择“Example2”观察页面发现name是注入点使用工具测试sqlmap参数为pythonsqlmap.py-u"http://192.168.29.148/sqli/......
  • 03-面试必会-Mysql篇
    1.Mysql查询语句的书写顺序Select[distinct]<字段名称>from表1[<join类型>join表2on<join条件>]where<where条件>groupby<字段>having<......
  • MySQL学习笔记-SQL实践1
    SQL实践1借着学校的数据库实验,来对之前学习的SQL语言进行实践和总结。实验环境:macOS13.2(22D49)mysqlVer8.0.32formacos13.0onarm64(Homebrew)DataGrip20......
  • PLSQL官方下载、安装和使用完全指南
    1、PLSQL介绍我们常说的plsql指的是plsqldeveloper这个oracle数据库客户端连接工具,这个工具以其方便和强大被广大开发者喜爱。这个工具是由allroundautomations公司开发,......
  • php连接docker运行的mysql,显示(HY000/2002): Connection refused的解决办法
    php连接docker运行的mysql,显示(HY000/2002):Connectionrefused的解决办法-斌哥tobin-博客园(cnblogs.com)php要连接docker中运行的mysql是不能用localhost,127.......
  • SQL语句
    1.表结构//创建表creattabletb_emp1( idint(11);namevarchar(25);deptldint(11);salaryfloat;);//修改表结构altertable<表名>[修改选项];......
  • SQL约束
    1、约束1.1约束在SQL中,约束是规定表中的数据规则。若存在违反约束的行为,行为就会被阻止。它能帮助管理员更好地管理数据库,并且确保数据库中数据的正确性和有效性。例......
  • sqlite 常见命令及操作
    sqlite系统命令sqlitetest.db                         创建test.db文件并进入sqlite3sqlite>.database  ......
  • sqlite3 命令行
    进入sqlite3命令行模式安装好sqlite3之后,在linux命令行中输入sqlite3,进入sqlite3的命令行模式。root@172:/#sqlite3SQLiteversion3.23.12018-04-1017......