Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Grupowanie wierszy z uwzględnieniem różnicy między wierszami

Używam podzapytań z analizą do identyfikowania i grupowania ciągłych zakresów:

SQL> WITH test_data AS (
  2    SELECT  0 s, 2 dur FROM dual UNION ALL   --# ■■
  3    SELECT  2  , 2     FROM dual UNION ALL   --#   ■■
  4    SELECT 10  , 1     FROM dual UNION ALL   --#           ■
  5    SELECT 13  , 4     FROM dual UNION ALL   --#              ■■■■
  6    SELECT 15  , 4     FROM dual             --#                ■■■■
  7  )
  8  SELECT MIN(s) "begin", MAX(s + dur) "end"
  9    FROM (SELECT s, dur, SUM(gap) over(ORDER BY s) my_group
 10             FROM (SELECT s, dur,
 11                           CASE
 12                              WHEN lag(s + dur) over(ORDER BY s) >= s - 5 THEN
 13                               0
 14                              ELSE
 15                               1
 16                           END gap
 17                      FROM test_data
 18                     ORDER BY s))
 19   GROUP BY my_group;

     begin        end
---------- ----------
         0          4
        10         19


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak dodać ograniczenie w Oracle SQL, aby ograniczyć wartość?

  2. Szyfrowanie Oracle Advanced Secuity z konfiguracją Spring JDBC xml

  3. jak zamienić wiele ciągów razem w Oracle

  4. Grupuj według, aby utworzyć pionową koalescencję

  5. Jak zamawiać według daty w PostgreSQL lub Oracle