在oracle签到表中
假设 1 是正常上班 2是迟到 3是请假 4是旷工
员工A 自上班以来的签到情况 是(按时间 desc) 222431...
现在需要统计他最近连续 迟到的次数 (请假、旷工不算迟到)
问:怎样编写 sql 才能统计出 他最近连续迟到3次?
也可以这样问 怎样编写 sql 才能统计出 他最近连续 非正常上班 次数?
在oracle当中统计连续迟到次数
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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 matlab有关常微分方程的问题求解决
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算
- ¥15 java如何提取出pdf里的文字?
- ¥100 求三轴之间相互配合画圆以及直线的算法
- ¥100 c语言,请帮蒟蒻写一个题的范例作参考
- ¥15 名为“Product”的列已属于此 DataTable