Menggunakan Operator Set

Operator set digunakan untuk menggabungkan hasil dari dua (atau lebih) pernyataan SELECT. Operator SET yang tersedia di Oracle 11g adalah UNION, UNION ALL, INTERSECT, dan MINUS.

Operator set UNION mengembalikan hasil gabungan dari dua pernyataan SELECT. Pada dasarnya, ini menghapus duplikat dari hasil yaitu hanya satu baris yang akan dicantumkan untuk setiap hasil duplikat.Untuk mengatasi perilaku ini, gunakan operator set UNION ALL yang mempertahankan duplikat di hasil akhir.INTERSECT daftar hanya catatan yang umum untuk kedua query SELECT; operator himpunan MINUS menghapus hasil kueri kedua dari keluaran jika hasil tersebut juga ditemukan di hasil kueri pertama. Operasi set INTERSECT dan MINUS menghasilkan hasil yang tidak digandakan.

Semua operator SET berbagi tingkat prioritas yang sama di antara mereka.Sebagai gantinya, selama eksekusi kueri, Oracle memulai evaluasi dari kiri ke kanan atau dari atas ke bawah.Jika secara eksplisit menggunakan tanda kurung, urutannya mungkin berbeda karena tanda kurung akan diberikan prioritas di atas operator yang menggantung.

Poin yang perlu diingat -

  • Jumlah kolom yang sama harus dipilih oleh semua pernyataan SELECT yang berpartisipasi. Nama kolom yang digunakan dalam tampilan diambil dari kueri pertama.

  • Tipe data dari daftar kolom harus kompatibel / dapat diubah secara implisit oleh oracle. Oracle tidak akan melakukan konversi tipe implisit jika kolom terkait dalam kueri komponen termasuk dalam grup tipe data yang berbeda. Misalnya, jika kolom dalam kueri komponen pertama adalah tipe data DATE, dan kolom terkait di kueri komponen kedua adalah data ketik CHAR, Oracle tidak akan melakukan konversi implisit, tetapi meningkatkan kesalahan ORA-01790.

  • Urutan posisi harus digunakan untuk mengurutkan kumpulan hasil. Pengurutan set hasil individu tidak diperbolehkan dengan operator Set. ORDER BY bisa muncul satu kali di akhir kueri. Sebagai contoh,

  • Operator UNION dan INTERSECT bersifat komutatif, yaitu urutan kueri tidak penting; itu tidak mengubah hasil akhir.

  • Dari segi kinerja, UNION ALL menunjukkan kinerja yang lebih baik dibandingkan dengan UNION karena sumber daya tidak terbuang percuma dalam memfilter duplikat dan menyortir kumpulan hasil.

  • Operator set dapat menjadi bagian dari sub queri.

  • Operator set tidak dapat digunakan dalam pernyataan SELECT yang berisi ekspresi koleksi TABLE.

  • Tabel LONG, BLOB, CLOB, BFILE, VARRAY, atau bersarang tidak diizinkan untuk digunakan di operator Set. Untuk klausa pembaruan tidak diizinkan dengan operator set.

PERSATUAN

Ketika beberapa kueri SELECT digabungkan menggunakan operator UNION, Oracle menampilkan hasil gabungan dari semua kueri SELECT yang digabungkan, setelah menghapus semua duplikat dan dalam urutan yang diurutkan (naik secara default), tanpa mengabaikan nilai NULL.

Pertimbangkan lima kueri di bawah ini yang digabungkan menggunakan operator UNION. Kumpulan hasil akhir gabungan berisi nilai dari semua SQL. Perhatikan penghapusan duplikasi dan pengurutan data.

SELECT 1 NUM FROM DUAL
UNION
SELECT 5 FROM DUAL 
UNION
SELECT 3 FROM DUAL
UNION
SELECT 6 FROM DUAL
UNION
SELECT 3 FROM DUAL;

NUM
-------
1
3
5
6

Untuk dicatat, kolom yang dipilih dalam kueri SELECT harus dari tipe data yang kompatibel. Oracle melempar pesan kesalahan saat aturan dilanggar.

SELECT TO_DATE('12-OCT-03') FROM DUAL
UNION
SELECT '13-OCT-03' FROM DUAL;

SELECT TO_DATE('12-OCT-03') FROM DUAL
       *
ERROR at line 1:
ORA-01790: expression must have same datatype as corresponding expression

UNI SEMUA

UNION dan UNION ALL memiliki fungsi yang serupa dengan sedikit perbedaan. Tetapi UNION ALL memberikan hasil yang ditetapkan tanpa menghapus duplikasi dan menyortir data. Misalnya, dalam kueri di atas UNION diganti dengan UNION ALL untuk melihat efeknya.

Pertimbangkan kueri yang ditunjukkan di bagian UNION. Perhatikan perbedaan keluaran yang dihasilkan tanpa penyortiran dan deduplikasi.

SELECT 1 NUM FROM DUAL
UNION ALL
SELECT 5 FROM DUAL 
UNION ALL
SELECT 3 FROM DUAL
UNION ALL
SELECT 6 FROM DUAL
UNION ALL
SELECT 3 FROM DUAL;

NUM
-------
1
5
3
6
3

MEMOTONG

Menggunakan operator INTERSECT, Oracle menampilkan baris umum dari kedua pernyataan SELECT, tanpa duplikat dan data diatur dalam urutan yang diurutkan (naik secara default).

Misalnya, kueri SELECT di bawah mengambil gaji yang umum di departemen 10 dan 20. Sesuai Standar ISO SQL, INTERSECT berada di atas yang lain dalam mendahului evaluasi operator yang ditetapkan tetapi ini masih belum dimasukkan oleh Oracle.

SELECT SALARY
FROM employees
WHERE DEPARTMENT_ID = 10
INTRESECT
SELECT SALARY 
FROM employees
WHERE DEPARTMENT_ID = 20

SALARY
---------
1500
1200
2000

MINUS

Operator minus menampilkan baris yang ada di kueri pertama tetapi tidak ada di kueri kedua, tanpa duplikat dan data diatur dalam urutan menaik secara default.

SELECT JOB_ID
FROM employees
WHERE DEPARTMENT_ID = 10
MINUS
SELECT JOB_ID
FROM employees
WHERE DEPARTMENT_ID = 20;

JOB_ID
-------------        
HR
FIN
ADMIN

Mencocokkan pernyataan SELECT

Mungkin ada skenario di mana pernyataan gabungan SELECT mungkin memiliki jumlah dan tipe data yang berbeda dari kolom yang dipilih. Oleh karena itu, untuk mencocokkan daftar kolom secara eksplisit, kolom NULL disisipkan pada posisi yang hilang agar sesuai dengan jumlah dan tipe data dari kolom yang dipilih di setiap pernyataan SELECT. Untuk kolom angka, nol juga bisa diganti agar sesuai dengan tipe kolom yang dipilih dalam kueri.

Dalam kueri di bawah ini, tipe data nama karyawan (varchar2) dan id lokasi (angka) tidak cocok. Oleh karena itu, eksekusi kueri di bawah ini akan menimbulkan kesalahan karena masalah kompatibilitas.

SELECT DEPARTMENT_ID "Dept", first_name "Employee"
FROM employees
UNION
SELECT DEPARTMENT_ID, LOCATION_ID
FROM departments;

ERROR at line 1:
ORA-01790: expression must have same datatype as corresponding expression

Secara eksplisit, kolom dapat dicocokkan dengan mengganti NULL untuk id lokasi dan nama Karyawan.

SELECT DEPARTMENT_ID "Dept", first_name "Employee", NULL "Location"
FROM employees
UNION
SELECT DEPARTMENT_ID, NULL "Employee", LOCATION_ID
FROM departments;

Menggunakan klausa ORDER BY dalam operasi SET

Klausa ORDER BY hanya dapat muncul sekali di akhir kueri yang berisi pernyataan gabungan SELECT. Ini menyiratkan bahwa pernyataan SELECT individu tidak dapat memiliki klausa ORDER BY. Selain itu, pengurutan dapat didasarkan pada kolom yang muncul di kueri SELECT pertama saja. Untuk alasan ini, disarankan untuk mengurutkan kueri gabungan menggunakan posisi kolom.

Kueri gabungan di bawah ini menyatukan hasil dari dua departemen dan mengurutkan menurut kolom GAJI.

SELECT employee_id, first_name, salary
FROM employees
WHERE department_id=10
UNION
SELECT employee_id, first_name, salary
FROM employees
WHERE department_id=20
ORDER BY 3;