oracle 查询每组数据中最新的一条数据

现在的表数据如下: 主要是车牌号,经纬度和创建时间.现要查询出每个车牌号最新的一条

 第一种写法:

 SELECT   CARNUM ,CREATEDATE, rank() OVER(PARTITION BY CARNUM ORDER BY CREATEDATE DESC)MAXCAR  FROM  MYTEST

 

 可以看出来,查询的时候 都给加上了序号,然后我们嵌套一层, 查询 MAXCAR 为1的就行

SELECT * from (SELECT   CARNUM ,CREATEDATE, rank() OVER(PARTITION BY CARNUM ORDER BY CREATEDATE DESC)MAXCAR  FROM  MYTEST) where  MAXCAR=1

这样就可以了

----------------------------

不过如上写法如果有重复的数据的话,我们还得去重,例如:

去重之后的效果:

第二种写法:借助 行号

SELECT CARNUM ,CREATEDATE, Row_Number() OVER(PARTITION BY CARNUM ORDER BY CREATEDATE DESC)MAXCAR  FROM  MYTEST

然后我们再取行号为1的

 

  • 10
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值