kino_s 2023-01-06 10:55 采纳率: 45.5%
浏览 127
已结题

SqlSever 关于时间字段的分组查询

现有一堆条码,其中尾数a/b表示一张制品的左右
问题是在录入过程中左右录入反了,即ID 1的SHT实际对应ID 2的PCS,以此类推

区分的思路是想利用EnterTime字段,因为经过排序后可以发现同制品a、b的录入时间间隔
非常接近,那么什么语句可以限定以1秒内,2秒内的时间间隔来分组查询这些条码呢?

简单语句尝试不出来,百度也基本只有大于多少小于多少时间这种方式

img

  • 写回答

7条回答 默认 最新

  • BLOOMOK 2023-01-10 09:40
    关注

    你可以使用以下语句来实现你的需求:

    SELECT * FROM table
    WHERE ABS(EnterTime - LAG(EnterTime, 1) OVER (PARTITION BY a ORDER BY EnterTime)) <= INTERVAL '2' SECOND
    AND ABS(EnterTime - LAG(EnterTime, 1) OVER (PARTITION BY b ORDER BY EnterTime)) <= INTERVAL '2' SECOND
    

    在上面的语句中,我们使用了 LAG 函数来查询每个制品的上一条记录的录入时间,并使用 ABS 函数求绝对值,然后使用 INTERVAL 函数指定时间间隔,最后使用 WHERE 子句来筛选出时间间隔在 1 秒内或 2 秒内的记录。

    你也可以使用 BETWEEN 子句来筛选出时间间隔在 1 秒内或 2 秒内的记录:

    SELECT * FROM table
    WHERE EnterTime BETWEEN LAG(EnterTime, 1) OVER (PARTITION BY a ORDER BY EnterTime) AND LAG(EnterTime, 1) OVER (PARTITION BY a ORDER BY EnterTime) + INTERVAL '2' SECOND
    AND EnterTime BETWEEN LAG(EnterTime, 1) OVER (PARTITION BY b ORDER BY EnterTime) AND LAG(EnterTime, 1) OVER (PARTITION BY b ORDER BY EnterTime) + INTERVAL '2' SECOND
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

问题事件

  • 系统已结题 1月21日
  • 已采纳回答 1月13日
  • 创建了问题 1月6日

悬赏问题

  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探