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 springboot+vue 集成keycloak sso到阿里云
  • ¥15 win7系统进入桌面过一秒后突然黑屏
  • ¥30 backtrader对于期货交易的现金和资产计算的问题
  • ¥15 求C# .net4.8小报表工具
  • ¥15 安装虚拟机时出现问题
  • ¥15 Selenium+docker Chrome不能运行
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到
  • ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
  • ¥50 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!