Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

UNPIVOT pada beberapa kolom untuk mengembalikan beberapa kolom

seperti ini:

SQL> select * from network_table;

 ORIG_CODE    ORIG_SV  DEST_CODE    DEST_SV
---------- ---------- ---------- ----------
        14          1         15          1
        12          2         22          2
        18          4         11          1
        15          1         22          3
        14          3         11          1

SQL> select case name when 'ORIG_SV' then orig_code else dest_code end code, val 
  2  from network_table 
  3  unpivot (val for name in (orig_sv, dest_sv));

      CODE        VAL
---------- ----------
        14          1
        15          1
        12          2
        22          2
        18          4
        11          1
        15          1
        22          3
        14          3
        11          1

atau 10g ke bawah:

SQL> select case  r when 1 then orig_code else dest_code end code,
  2         case r when 1 then orig_sv else dest_sv end val
  3    from network_table, (select rownum r from dual connect by level <= 2)
  4  /

      CODE        VAL
---------- ----------
        14          1
        12          2
        18          4
        15          1
        14          3
        15          1
        22          2
        11          1
        22          3
        11          1


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle masukkan ke dalam pengembalian

  2. Urutan baris default untuk kueri pemilihan di Oracle

  3. Apakah Oracle menggunakan evaluasi hubung singkat?

  4. Mengubah kolom menjadi baris di Oracle

  5. Lewati array sebagai parameter input ke prosedur tersimpan Oracle menggunakan panggilan jdbc sederhana