首页数据库postgres 实现查询某条数据的排名

postgres 实现查询某条数据的排名

时间2024-02-29 14:22:03发布访客分类数据库浏览1015
导读:收集整理的这篇文章主要介绍了postgres 实现查询某条数据的排名,觉得挺不错的,现在分享给大家,也给大家做个参考。 我就废话不多说了,大家还是直接看代码吧~select * From...
收集整理的这篇文章主要介绍了postgres 实现查询某条数据的排名,觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

您可能感兴趣的文章:
  • postgresql数据库根据年月查询出本月的所有数据操作
  • postgresql通过索引优化查询速度操作
  • postgresql查询锁表以及解除锁表操作
  • Postgresql 实现查询一个表/所有表的所有列名

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: postgres 实现查询某条数据的排名
本文地址: https://pptw.com/jishu/632979.html
Python怎么列出目录中的所有文件 php遍历一个数组的方法有哪些

游客 回复需填写必要信息