SQL-запрос для сравнения значений столбцов - PullRequest
0 голосов
/ 18 марта 2019

У меня ниже шаблон данных и мне нужно написать SQL для проверки сценариев тестирования, как показано ниже. Это просто пример, в моей таблице миллионы записей, и для проверки требуется sql. Любая помощь / предложение будет очень признателен.

  1. EFEC_FROM из RANK_ORDER 2 = EFEC_2 из RANK_ORDER = 1
  2. EFEC_FROM из RANK_ORDER 3 = EFEC_2 из RANK_ORDER = 2
  3. EFEC_FROM из RANK_ORDER 4 = EFEC_2 из RANK_ORDER = 3

И данные:

S_KEY FLAG_1  FLAG_2    EFEC_FROM                   EFEC_2                     RANK_ORDER   
100   1       0         2019-02-28 15:04:00.000000  2019-02-28 15:13:00.006000  1
100   0       0         2019-02-28 15:13:00.006000  2019-02-28 15:19:00.011000  2
100   0       0         2019-02-28 15:19:00.011000  2019-02-28 15:20:00.014000  3
100   0       1         2019-02-28 15:20:00.014000  2099-12-31 00:00:00.000000  4

Ответы [ 2 ]

0 голосов
/ 18 марта 2019

Вам определенно необходимо использовать функции LAG / LEAD для получения информации из предыдущей или следующей строки в наборе данных.

SELECT * FROM (
SELECT s_key,
       flag_1,
       flag_2,
       efec_from,
       efec_2,
       rank_order
       NVL (   LEAD (efec_from, 1)
               OVER (PARTITION BY s_key 
                         ORDER BY rank_order),
               '2099-12-31') AS next_efec_2
  FROM table)
WHERE efec_2 <> next_efec_from

Дополнительный источник информации LAG / LEAD: https://docs.teradata.com/reader/756LNiPSFdY~4JcCCcR5Cw/NbZIb7BVEkYT9tMbXxOuog

0 голосов
/ 18 марта 2019

Чтобы узнать, какие строки не соответствуют правилу проверки, вы можете использовать функции LAG() или LEAD(), например:

with 
x as (
  select
    s_key, flag_1, flag_2, efec_from, efec_2, rank_order,
    lag(efec_2 order by rank_order) prev_efec_2
from my_table
)
select *
from x
where efec_from <> prev_efec_2
...