NULLIF из FINAL SUM удваивается при использовании MATCH_RECOGNIZE - PullRequest
0 голосов
/ 01 мая 2020

Когда я запускаю следующий код, я ожидаю, что b1 и b2 будут равны, однако b2 удваивается. Я делаю что-то неправильно? Это ошибка в базе данных? Мы бежим Oracle 12c (12.2.0.1.0).

WITH TBL AS
  (
  SELECT 1 a, 1 b FROM DUAL UNION ALL
  SELECT 1 a, 2 b FROM DUAL UNION ALL
  SELECT 1 a, 3 b FROM DUAL UNION ALL
  SELECT 1 a, 4 b FROM DUAL
  )
SELECT
  *
FROM
  TBL
MATCH_RECOGNIZE
  (
  PARTITION BY
    a
  ORDER BY
    b
  MEASURES
    FINAL SUM(b) b1,
    NULLIF(FINAL SUM(b), 0) b2
  ALL ROWS PER MATCH WITH UNMATCHED ROWS
  AFTER MATCH SKIP PAST LAST ROW
  PATTERN
    (C*)
  DEFINE
    C AS B > 0
  ) mr

Результат:

| A | B | B1 | B2 |
|---|---|----|----|
| 1 | 1 | 10 | 20 |
| 1 | 2 | 10 | 20 |
| 1 | 3 | 10 | 20 |
| 1 | 4 | 10 | 20 |

1 Ответ

0 голосов
/ 01 мая 2020

Кажется, проблема в NULLIF, когда я преобразовал его в логический эквивалент, и он работает нормально CASE WHEN expr1 = expr 2 THEN NULL ELSE expr1 END

WITH TBL AS
      (
      SELECT 1 a, 1 b FROM DUAL UNION ALL
      SELECT 1 a, 2 b FROM DUAL UNION ALL
      SELECT 1 a, 3 b FROM DUAL UNION ALL
      SELECT 1 a, 4 b FROM DUAL
      )
    SELECT
      *
    FROM
      TBL
    MATCH_RECOGNIZE
      (
      PARTITION BY
        a
      ORDER BY
        b
      MEASURES
        FINAL SUM(b) b1,
       CASE WHEN FINAL SUM(b)=0 THEN NULL ELSE FINAL SUM(b) END b2
      ALL ROWS PER MATCH WITH UNMATCHED ROWS
      AFTER MATCH SKIP PAST LAST ROW
      PATTERN
        (C*)
      DEFINE
        C AS B > 0
      ) mr 

Результат

    | A | B | B1 | B2 |
    |---|---|----|----|
    | 1 | 1 | 10 | 10 |
    | 1 | 2 | 10 | 10 |
    | 1 | 3 | 10 | 10 |
    | 1 | 4 | 10 | 10 |
...