Oracle 多 case 语句

Oracle multiple case statements

我正在尝试使用 case 语句创建 2 个标志。

Flag1 = event_per_month
Flag2 = event_per_day

下面是示例数据

我希望根据每天和每月的 id 出现次数创建两个标志。

EVENT_PER_DAY 逻辑:如果给定的 id 和 msg 在同一天重复多次,则对于重复事件(id 和 msg 的组合),event_per_day 标志变为 "T"否则它仍然是 "T".

EVENT_PER_MONTH 逻辑:如果给定的 id 和 msg 在同一个月重复多次,则 event_per_month 标志变为 "T" 重复事件(id 和 msg 的组合)否则它仍然是 "T".

我使用了 case 语句,但这里的问题是我有日期和月份列,这使得它有点复杂。

这是预期的结果

id  error_date  error_month error category  event_per_day   event_per_month
123 15-May-15 12:01:01  May-15  msg1    F   F
123 15-May-15 12:20:00  May-15  msg1    T   T
123 17-May-15 22:00:00  May-15  msg2    F   F
124 17-May-15 20:00:00  May-15  msg2    T   T
123 18-May-15 12:00:00  May-15  msg3    F   F
123 19-May-15 19:00:00  May-15  msg3    F   F
123 20-May-15 12:00:00  May-15  msg4    F   F
123 20-May-15 17:00:00  May-15  msg4    T   T
123 22-May-15 12:00:00  May-15  msg4    F   F
123 23-May-15 12:00:00  May-15  msg4    F   F
123 12-Aug-15 18:00:00  Aug-15  msg1    F   F
123 13-Aug-15 12:00:00  Aug-15  msg2    F   F
123 14-Aug-15 12:00:00  Aug-15  msg3    F   F
123 15-Aug-15 12:00:00  Aug-15  msg4    F   F
123 16-Aug-15 12:00:00  Aug-15  msg1    F   T
123 17-Aug-15 12:00:00  Aug-15  msg1    F   T
123 18-Aug-15 12:00:00  Aug-15  msg2    F   T
123 19-Aug-15 12:00:00  Aug-15  msg3    F   T
123 20-Aug-15 12:00:00  Aug-15  msg4    F   T
123 21-Aug-15 12:00:00  Aug-15  msg3    F   T
890 15-May-15 12:01:01  May-15  msg1    F   F
890 15-May-15 12:20:00  May-15  msg1    T   T
890 17-May-15 22:00:00  May-15  msg2    F   F
890 17-May-15 20:00:00  May-15  msg2    T   T
890 18-May-15 12:00:00  May-15  msg3    F   F
890 19-May-15 19:00:00  May-15  msg3    F   F
890 20-May-15 12:00:00  May-15  msg4    F   F
890 20-May-15 17:00:00  May-15  msg4    T   T
890 22-May-15 12:00:00  May-15  msg4    F   F
890 23-May-15 12:00:00  May-15  msg4    F   F
890 12-Aug-15 18:00:00  Aug-15  msg1    F   F
890 13-Aug-15 12:00:00  Aug-15  msg2    F   F
890 14-Aug-15 12:00:00  Aug-15  msg3    F   F
890 15-Aug-15 12:00:00  Aug-15  msg4    F   F
890 16-Aug-15 12:00:00  Aug-15  msg1    F   T
890 17-Aug-15 12:00:00  Aug-15  msg1    F   T
890 18-Aug-15 12:00:00  Aug-15  msg2    F   T
890 19-Aug-15 12:00:00  Aug-15  msg3    F   T
890 20-Aug-15 12:00:00  Aug-15  msg4    F   T
890 21-Aug-15 12:00:00  Aug-15  msg3    F   T

我想你想要解析函数:

select t.*,
       (case when row_number() over (partition by trunc(error_date), msg
                                     order by error_date
                                    ) = 1
             then 'F' else 'T'
        end) as event_per_day,
       (case when row_number() over (partition by error_month, msg
                                     order by error_date
                                    ) = 1
             then 'F' else 'T'
        end) as event_per_month
from table t;

编辑:

上面的查询应该没问题,但也许使用子查询会有所帮助:

select t.*,
       (case when seqnum_day = 1 then 'F' else 'T' end) as event_per_day,
       (case when seqnum_mon = 1 then 'F' else 'T' end) as event_per_month
from (select t.*,
             row_number() over (partition by trunc(error_date), msg
                                order by error_date) as seqnum_day,
             row_number() over (partition by error_month, msg
                                order by error_date) as seqnum_mon
      from table t
     ) t;