zoukankan      html  css  js  c++  java
  • sql 实现取表中相同id时间最大的一行 利用distinct on

    数据表是这样的

    select * from water_level_records  m where (
            select count(*) from water_level_records n where m.device_id = n.device_id and m.record_time < n.record_time
            ) < 1

    这个sql的逻辑是把一个表当做两个表关联来使用,当满足m的记录时间小于n的记录时间的数量<1 即只有一个相等时返回,即是时间的最大值, 如果为<2 则是为前两大的值,这里以device_id为唯一关联

    一种更搞笑的方法如下

    SELECT DISTINCT on (device_id ) device_id  ,record_time from water_level_records order by device_id , record_time desc 

    这里DISTINCT on的用法和效果与DISTINCT不同,如果这里为DISTINCT 则 device_id   record_tiem 这两列有一列不同就满足唯一性。而distinct on的效果为不管后面跟了几列,必须保持device_id的唯一性 

    这里加上order by record_time desc 的效果为只取时间最大的一项。另注意DISTINCT on (device_id ) 如果加order by 的话 order by device_id必填

  • 相关阅读:
    套题 8.22
    套题 8.21
    P1042 乒乓球
    套题8.20
    #52. 【UR #4】元旦激光炮 (交互式题)
    #82. 【UR #7】水题生成器
    度度熊与邪恶大魔王
    wpf 获取image控件的图片并保存
    wpf 让正执行的程序暂停几秒钟
    wpf问题集锦
  • 原文地址:https://www.cnblogs.com/wangshaowei/p/11042392.html
Copyright © 2011-2022 走看看