oracle,一张表有很多重复的名字,查询出每个名字下最新的一条数据且状态正常

本文介绍了一种使用SQL的高级技巧,通过row_number() over(partition by)函数结合order by子句,有效地从大量数据中筛选出每个用户最新的记录。这种方法在处理时间序列数据时尤其有效,能够确保数据的时效性和准确性。
select c.NAME ,c.SJ,c.RZMS
from
(select t.NAME ,t.SJ,t.RZMS,row_number() over(partition by t.NAME order by t.SJ desc) n
from T_FWZX_BE_WXJKRZ t WHERE t.RZZT='正常') c
where n = 1

很关键的语句“row_number() over(partition by t.NAME order by t.SJ desc”,这里n代表着每个名字根据时间进行降序排列的序号,“n=1”就代表每个名字的第一条数据,因为这里是根据时间降序,所以第一条就是每个名字的最新的一条数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值