我就废话不多说了,大家还是直接看代码吧~

select * from (select ROW_NUMBER () OVER (ORDER BY fat desc nulls last) AS xuhao,foodnum,foodname,fat from ek_food where isdel=0) food where foodnum = 'Ss192008'

涉及到的问题

1.排序时,字段值为null的会排在前面,导致数据不准确,解决办法 在order by后面增加 nulls last

2.给查询的结果增加序号 select ROW_NUMBER () OVER (ORDER BY fat desc nulls last) AS xuhao

补充:利用 PostgreSQL 实现对数据进行排名

一、需求:对以下用户的积分进行排名计算

user_id name score 1 john 1000 2 mike 1200 3 jelly 1300 4 brook 1500 5 nanny 1200

需要知道 user_id = k 的用户对应的积分排名

二、通过 PostgreSQL 的窗口函数实现

SELECT user_id, name, score, RANK() OVER (ORDER BY score DESC) FROM user;

user_id name score rank 4 brook 1500 1 3 jelly 1200 2 2 mike 1300 3 5 nanny 1500 3 1 john 1200 5

如要获取排名 < 3 的用户:

SELECT user_id, name, score, user_rank FROM (SELECT user_id, name, score, RANK() OVER (ORDER BY score DESC) AS user_rank FROM user) AS T WHERE user_rank < 3;

-- 注意子查询在from中需要写别名

user_id name score rank 4 brook 1500 1 3 jelly 1200 2

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。

标签:
postgres,,查询数据排名

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“postgres 实现查询某条数据的排名”

暂无“postgres 实现查询某条数据的排名”评论...

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。