主流SQL查询多条只取其中最新的一条数据

业务场景:

      ORACLE可以查看:oracle针对多数据只取最新一条的sql_Cx_轩的博客-CSDN博客_oracle rn=1

      MYSQL可以查看:MYSQL系列-Mysql针对多条数据获取最新一条数据时的sql语句_Cx_轩的博客-CSDN博客

      在针对某个类型数据存在多条时,但只想取最新的一条。在可以确定时哪种类型时我们使用简单sql就可以解决。

      ORACLE-SQL:

      如: select * from ( select * from t_table a where a.tpye=? order by a.time desc ) where rownum=1;

      MYSQL-SQL:

      如: select * from t_table a where a.type=?  order by time desc limit1;

     但是在我们不确定时哪种类型时,需要全表扫描或者多数据扫描时,就需要用到oracle中特有的函数解决了。

     ORACLE-SQL:

     如:select * from (select  a.type,row_number() over(partition by a.type order by a.time desc) as rn from t_table a where xxxx) where rn=1;

     MYSQL-SQL:

     如:select a.type,max(id) from( select * from t_table  order by time desc ) a group by a.type;

     或者: select * from t_table order by time desc limit 1;

    其中partition by后面跟的字段表示根据此字段去区分跟分组,order by 进行排序,row_number() over 这个表示根据里面的条件去获取行数,

    总结这个函数的意思:根据type字段分组根据time字段排序后,获取此type在表中存在多少数据(存在多少则表示rn有多少行)rn=1表示取第一行也就拿到了最新的数据。

partition by相比较于group by,能够在保留全部数据的基础上,只对其中某些字段做分组排序(类似excel中的操作),而group by则只保留参与分组的字段和聚合函数的结果。

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值