首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将一列中具有相同值的连续行减少为单行

将一列中具有相同值的连续行减少为单行
EN

Stack Overflow用户
提问于 2019-09-19 18:26:54
回答 1查看 59关注 0票数 1

我正在尝试创建一个从生物识别设备接收数据的生物识别考勤系统。

从该设备接收到的出席表的结构如下所示。

该表最初有很多具有多个emp_no的数据,但是我创建了一个存储过程来提取一个员工在特定日期的详细信息,如上所示。现在面临的挑战是,我需要分析这个表并重新构造它(重新创建另一个表),以便它具有交替的签入和签出(每次签入之后必须有一个签出,反之亦然),对于连续的签入,我应该使用较早的签入,而对于连续的签出,我应该使用最新的签入。任何关于如何做到这一点的想法都将非常感谢。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-19 18:47:42

使用窗口函数lag()lead()

代码语言:javascript
复制
select emp_id, att_date, att_time, status
from (
    select 
        emp_id, att_date, att_time, status, 
        case 
            when status = 'checkin' then lag(status) over w is distinct from 'checkin'
            else lead(status) over w is distinct from 'checkout'
        end as visible
    from my_table
    window w as (partition by emp_id, att_date order by att_time)
    ) s
where visible

Db<>fiddle.

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58008966

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档