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;
相关推荐
百结2147 小时前
Mysql数据库操作
数据库·mysql·oracle
keep one's resolveY7 小时前
时区问题解决
数据库
Leinwin7 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
qq_417695057 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水8 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
ego.iblacat8 小时前
MySQL 服务基础
数据库·mysql
Maverick069 小时前
Oracle Redo 日志操作手册
数据库·oracle
攒了一袋星辰10 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
W.D.小糊涂10 小时前
gpu服务器安装windows+ubuntu24.04双系统
c语言·开发语言·数据库
云贝教育-郑老师10 小时前
【OceanBase 的多租户架构是怎样的?有什么优势?】
数据库·oceanbase