deallyge 2014-11-22 06:17 采纳率: 0%
浏览 2119

在oracle当中统计连续迟到次数

在oracle签到表中
假设 1 是正常上班 2是迟到 3是请假 4是旷工
员工A 自上班以来的签到情况 是(按时间 desc) 222431...
现在需要统计他最近连续 迟到的次数 (请假、旷工不算迟到)
问:怎样编写 sql 才能统计出 他最近连续迟到3次?
也可以这样问 怎样编写 sql 才能统计出 他最近连续 非正常上班 次数?

  • 写回答

3条回答 默认 最新

  • bw555 2014-11-22 12:22
    关注

    签到是怎么存储的?
    姓名 日期 状态?按这个结构给你写吧
    --下面语句可查出设定日期之后连续3天迟到的人员名单
    --listagg 11g以后可用
    select 姓名
    from T
    where 日期>=设定日期
    GROUP BY 姓名
    having regexp_like(listagg(状态,'') within group (order by 日期),'222')

    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)