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日

悬赏问题

  • ¥30 dbLinq最新版linq sqlite
  • ¥20 对D盘进行分盘之前没有将visual studio2022卸载掉,现在该如何下载回来
  • ¥15 完成虚拟机环境配置,还有安装kettle
  • ¥15 2024年全国大学生数据分析大赛A题:直播带货与电商产品的大数据分析 问题5. 请设计一份优惠券的投放策略,需要考虑优惠券的数量、优惠券的金额、投放时间段和投放商品种类等因素。求具体的python代码
  • ¥15 有人会搭建生鲜配送自营+平台的管理系统吗
  • ¥15 用matlab写代码
  • ¥30 motoradmin系统的多对多配置
  • ¥15 求组态王串口自定义通信配置方法或代码?
  • ¥15 实验 :UML2.0 结构建模
  • ¥20 用vivado写数字逻辑实验报告撰写,FPGA实验