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必填

  • 相关阅读:
    Bootstrap表格的使用
    [JS练习] 瀑布流照片墙
    [C#基础] 委托
    [C#基础] 泛型
    [C#基础] 继承
    [C#基础] 类
    [C#基础] 数据类型
    Unity获取手机的电量时间
    C#网络通信Socket详解
    记C#一次服务器搭建和数据库应用
  • 原文地址:https://www.cnblogs.com/wangshaowei/p/11042392.html
Copyright © 2011-2022 走看看