MySQL5.7实现分组排序

文章目录


前言

`

MySQL5.7版本没有row_number()over()函数,MySQL8以上版本才有,但是MySql5.7安装的版本较多,在5.7如何进行排序分组。


一、准备数据

sql 复制代码
 CREATE TABLE POSTS(POST_ID INT,
				   USER_ID INT, -- 用户ID
				   CATEGORY_ID INT,-- 分类ID
				   POST_TITLE VARCHAR(400), 
				   CREATE_TIME DATE, -- 创建时间
				   LAST_EDIT_TIME DATE, -- 最后编辑时间
				   VIEW_COUNT INT,-- 访问量
				   REPLY_COUNT INT -- 回复量
				   );
				  
	
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(1,1,1,'标题1',now(),now(),100,400);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(2,1,1,'标题2',now(),now(),200,300);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(3,2,1,'标题3',now(),now(),300,200);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(4,2,1,'标题4',now(),now(),400,100);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(5,2,1,'标题5',now(),now(),500,100);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(6,1,2,'标题4',now(),now(),600,100);
INSERT INTO POSTS(POST_ID,USER_ID,CATEGORY_ID,POST_TITLE,CREATE_TIME,LAST_EDIT_TIME,VIEW_COUNT,REPLY_COUNT)VALUES(7,2,2,'标题5',now(),now(),700,100);

二、查询

根据查询各个分类的访问量的排名

sql 复制代码
SELECT A.*,@last :=IF(@FIRST = A.CATEGORY_ID, @last + 1, 1 ) AS rn, @FIRST := A.CATEGORY_ID 
FROM POSTS A,(SELECT @last := 0, @FIRST := NULL ) B
ORDER BY A.CATEGORY_ID,VIEW_COUNT DESC;
相关推荐
东方轧线2 分钟前
给 AI 安装高速缓存:实战 MCP 对接 Redis,实现热点数据的毫秒级读取与状态共享
数据库·人工智能·redis
2401_8322981017 分钟前
腾讯云TSearch存算分离,破解日志分析算力瓶颈
大数据·运维·数据库
Leo July38 分钟前
【MySQL】MySQL数据库调优实战指南:从基础优化到架构升级
数据库·mysql·架构
l1t44 分钟前
DeepSeek总结的在单节点上处理 1TB Parquet 数据方法
数据库·人工智能·duckdb
么么...1 小时前
系统性 MySQL 优化:性能分析、索引设计与失效场景全解
数据库·经验分享·sql·mysql
heartbeat..1 小时前
数据库性能优化:优化的时机(表结构+SQL语句+系统配置与硬件)
java·数据库·mysql·性能优化
YongCheng_Liang1 小时前
分布式数据库核心原理深度解析:架构、理论与事务解决方案
运维·数据库·sql
UrSpecial1 小时前
IM项目——文件管理子服务
服务器·数据库·oracle
一个响当当的名号1 小时前
lectrue6 缓冲池
数据库
小唐同学爱学习1 小时前
缓存与数据库一致性问题
java·数据库·spring boot·缓存