统计订单总数并列出排名

这是统计订单金额,并倒序列出,但还没有排名

SELECT sum(price) as total,uid FROM order WHERE paid = 1 GROUP BY uid ORDER BY total desc

下面的就增加了排名,其实就是把上面的作为子查询查出

*注:*1、 SELECT @rownum := 0:表示对rownum赋初始值0

2、@rownum := @rownum + 1:表示对rownum加1,语句中会从1开始,每一行往下都自动加1

SELECT A.*, @rank:=@rank+1 AS pm FROM (SELECT sum(price) as total,uid FROM order WHERE paid = 1 GROUP BY uid ORDER BY total desc) A, (SELECT @rank:=0) B;

如果想查询指定用户的排名

SELECT C.* FROM (SELECT A.*, @rank:=@rank+1 AS pm FROM (SELECT sum(total_price_kd) as total,uid FROM eb_store_order WHERE paid = 1 GROUP BY uid ORDER BY total desc) A, (SELECT @rank:=0) B) C where uid =10086

相关推荐
廿一夏1 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim3 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室4 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)4 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜4 小时前
Java项目常用数据归档方式
mysql
YOU OU5 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng6 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen6 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室6 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿7 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试