ORACLE SQL思路: 多行数据有相同字段就合并成一条数据 分页展示

数据

分数表:

学号,科目名(A,B,C),分数

需求

分页列表展示, 如果一个学号的科目有相同的分数, 合并成一条数据,用 + 拼接 科目名

ORACLE SQL 实现

sql 复制代码
SELECT Z.*,
SUBSTR(
	DECODE(fa.科目,null,'','+'||fa.科目)
|| DECODE(fb.科目,null,'','+'||fb.科目)	
|| DECODE(fc.科目,null,'','+'||fc.科目)	
,2 ) as 学科组合名称
FROM (
SELECT A.* FROM    (
SELECT 学号,分数  , ROW_NUMBER() OVER (order by 分数 desc,学号 ) as rn
FROM 分数表 WHERE ....  GROUP BY 学号 , 分数 
					)  A WHERE  A.rn BETWEEN 分页开始行 AND 分页结束行
)Z
	LEFT JOIN 分数表 fa ON fa.学号=Z.学号 AND fa.科目='A' AND fa.分数 =Z.分数
	LEFT JOIN 分数表 fb ON fb.学号=Z.学号 AND fb.科目='B' AND fb.分数 =Z.分数
	LEFT JOIN 分数表 fc ON fc.学号=Z.学号 AND fc.科目='C' AND fc.分数 =Z.分数
ORDER BY Z.分数 asc, Z.学号			
	

转换

如果相同字段是 天数差

sql 复制代码
, ( TRUNC(Z.时间) - TRUNC(to_date('2024-12-09', 'YYYY-MM-DD')) ) as 相差天数
相关推荐
gugugu.34 分钟前
Redis 字符串类型完全指南:从原理到实战应用
数据库·redis·缓存
杨云龙UP42 分钟前
MySQL 自动备份与覆盖恢复实战:一套脚本搞定全库/按库备份恢复
linux·运维·数据库·sql·mysql
workflower2 小时前
PostgreSQL 数据库优化
数据库·团队开发·数据库开发·时序数据库·数据库架构
计算机毕设VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue服装商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·课程设计
WX-bisheyuange4 小时前
基于Spring Boot的智慧校园管理系统设计与实现
java·大数据·数据库·毕业设计
JavaGuide4 小时前
对标MinIO!全新一代分布式文件系统诞生!
数据库·后端
快乐非自愿4 小时前
数据库如何处理大量的交易流水记录
数据库·oracle
IvorySQL5 小时前
瀚高硬核助力 PG 社区:Postgres 19 迎来并行 TID 范围扫描,速度提升 3 倍
数据库·postgresql·开源
ServBay5 小时前
MongoDB 的文档模型与 CRUD 实战
数据库·后端·mongodb
ITMr.罗5 小时前
深入理解EF Core更新机制(开发中因为省事遇到的问题)
服务器·数据库·c#·.net