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;
我正在尝试使用 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;