Как рассчитать изменения в Oracle SQL - PullRequest
0 голосов
/ 18 февраля 2019

У меня есть следующая таблица со следующими столбцами:

HID_1 HID_2 Attr1 Attr2 Attr3 Attr4  Attr5    
123   111    wo     e    ak    ERR   20180630    
123   111    wo     e    ak    ERR   20180730     
123   111    wo     e    ak    ERR   20180830     
123   111    qe     e    ak    ERR   20180930    
123   111    qe     e    ak    ERR   20181030    
123   111    aa     a    ak    ERR   20181130

Где HID_1 и HID_2 - это хэш-идентификаторы, остальные 4 столбца определяются оператором group by, а последний - time_id (date ofпоследний день месяца).В общем, в этой таблице у меня намного больше записей с большим количеством разных HID.

Я хочу отметить ряд изменений (в Attr1 - Attr4) для HID_2 в виде отдельного столбца.Исходя из первого примера, ответ должен быть таким:

HID_1 HID_2 Attr1 Attr2 Attr3 Attr4  Attr5     Attr6    
123   111    wo     e    ak    ERR   20180630   0    
123   111    wo     e    ak    ERR   20180730   0    
123   111    wo     e    ak    ERR   20180830   0    
123   111    qe     e    ak    ERR   20180930   1     
123   111    qe     e    ak    ERR   20181030   0    
123   111    aa     a    ak    ERR   20181130   2

Как мне это сделать в Oracle sql Database?

Ответы [ 2 ]

0 голосов
/ 18 февраля 2019

Попробуйте это:

select t.* 
, case when attr1 != LAG(attr1, 1, attr1) OVER (PARTITION BY hid_1, hid_2 ORDER BY attr5) then 1 else 0 end +
  case when attr2 != LAG(attr2, 1, attr2) OVER (PARTITION BY hid_1, hid_2 ORDER BY attr5) then 1 else 0 end +
  case when attr3 != LAG(attr3, 1, attr3) OVER (PARTITION BY hid_1, hid_2 ORDER BY attr5) then 1 else 0 end +
  case when attr4 != LAG(attr4, 1, attr4) OVER (PARTITION BY hid_1, hid_2 ORDER BY attr5) then 1 else 0 end as attr6
from t
0 голосов
/ 18 февраля 2019

Я думаю, что вы хотите:

select t.*,
       dense_rank() over (partition by hid_1, hid_2 order by min_attr5) as attr6
from (select t.*,
             min(attr5) over (partition by hid_1, hid_2, , attr1, attr2, attr3, attr4, seqnum_2 - seqnum) as min_attr5
      from (select t.*,
                   row_number() over (partition by hid_1, hid_2 order by attr5) as seqnum,
                   row_number() over (partition by hid_1, hid_2, attr1, attr2, attr3, attr4 order by attr5) as seqnum_2
            from t
      ) t;
...