Dapatkan Data dari Beberapa Tabel

Menampilkan Data dari Beberapa Tabel

Tabel terkait dari database besar ditautkan melalui penggunaan kunci asing dan primer atau yang sering disebut sebagai kolom umum. Kemampuan untuk menggabungkan tabel akan memungkinkan Anda untuk menambahkan lebih banyak makna ke tabel hasil yang dihasilkan. Untuk tabel angka 'n' yang akan digabungkan dalam kueri, kondisi penggabungan minimum (n-1) diperlukan. Berdasarkan kondisi gabungan, Oracle menggabungkan pasangan baris yang cocok dan menampilkan salah satu yang memenuhi kondisi gabungan.

Gabungan diklasifikasikan seperti di bawah ini

  • Gabungan alami (juga dikenal sebagai equijoin atau gabungan sederhana) - Membuat gabungan menggunakan kolom yang diberi nama dan ditentukan secara umum.

  • Gabungan non-kesetaraan - Menggabungkan tabel jika tidak ada baris yang setara dalam tabel yang akan digabungkan - misalnya, untuk mencocokkan nilai dalam satu kolom tabel dengan rentang nilai di tabel lain.

  • Gabung mandiri - Menggabungkan tabel ke dirinya sendiri.

  • Gabungan luar - Menyertakan rekaman tabel dalam output saat tidak ada rekaman yang cocok di tabel lain.

  • Gabungan kartesius (juga dikenal sebagai produk Kartesius atau gabungan silang) - Mereplikasi setiap baris dari tabel pertama dengan setiap baris dari tabel kedua. Membuat gabungan antar tabel dengan menampilkan setiap kombinasi rekaman yang memungkinkan.

Bergabung Alami

Kata kunci NATURAL dapat menyederhanakan sintaks dari sebuah equijoin. Sebuah NATURAL JOIN dimungkinkan setiap kali dua (atau lebih) tabel memiliki kolom dengan nama yang sama, dan kolom digabungkan kompatibel, yaitu kolom memiliki domain nilai bersama. Operation menggabungkan baris dari tabel yang memiliki nilai kolom yang sama untuk kolom bernama yang sama.

Pertimbangkan hubungan satu-ke-banyak antara tabel DEPARTMENTS dan EMPLOYEES. Setiap tabel memiliki kolom bernama DEPARTMENT_ID. Kolom ini adalah kunci utama dari tabel DEPARTMENTS dan kunci asing dari tabel EMPLOYEES.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E NATURAL JOIN departments D;

FIRST_NAME DNAME
---------- ------
MILLER     DEPT 1
JOHN       DEPT 1
MARTIN     DEPT 2
EDWIN      DEPT 2

Query SELECT di bawah ini menggabungkan dua tabel dengan secara eksplisit menentukan kondisi gabungan dengan kata kunci ON.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E JOIN departments D
ON (E.department_id = D.department_id);

Ada beberapa batasan terkait NATURAL JOIN. Anda tidak dapat menentukan kolom LOB dengan NATURAL JOIN. Juga, kolom yang terlibat dalam gabungan tidak dapat dikualifikasikan dengan nama tabel atau alias.

MENGGUNAKAN Klausul

Dengan menggunakan gabungan Natural, Oracle secara implisit mengidentifikasi kolom untuk membentuk basis gabungan. Banyak situasi membutuhkan pernyataan eksplisit dari kondisi bergabung. Dalam kasus seperti itu, kami menggunakan klausa MENGGUNAKAN untuk menentukan kriteria penggabungan. Karena, klausa USING menggabungkan tabel berdasarkan persamaan kolom, ini juga dikenal sebagai Equijoin. Mereka juga dikenal sebagai gabungan dalam atau gabungan sederhana.

Sintaksis:

SELECT <column list>
FROM   TABLE1   JOIN   TABLE2	
USING (column name)

Pertimbangkan query SELECT di bawah ini, tabel EMPLOYEES dan tabel DEPARTMENTS digabungkan menggunakan kolom umum DEPARTMENT_ID.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E JOIN departments D
USING (department_id);

Bergabung Sendiri

Operasi SELF-JOIN menghasilkan tabel hasil jika ada hubungan yang diminati di antara baris yang disimpan dalam satu tabel. Dengan kata lain, ketika tabel digabungkan dengan tabel itu sendiri, gabungan tersebut disebut Self Join.

Pertimbangkan tabel KARYAWAN, yang berisi karyawan dan manajer pelaporan mereka.Untuk menemukan nama manajer untuk seorang karyawan akan membutuhkan gabungan di tabel EMP itu sendiri. Ini adalah kandidat khas untuk Self Join.

SELECT e1.FirstName Manager,e2.FirstName Employee
FROM employees e1 JOIN employees e2
ON (e1.employee_id = e2.manager_id)
ORDER BY e2.manager_id DESC;

Bukan Equijoins

Gabungan non-kesetaraan digunakan saat kolom terkait tidak dapat digabungkan dengan tanda yang sama-artinya tidak ada baris yang setara dalam tabel untuk digabungkan. Gabungan non-kesetaraan memungkinkan Anda menyimpan nilai minimum rentang dalam satu kolom dari catatan dan nilai maksimum di kolom lain. Jadi, alih-alih menemukan kecocokan kolom-ke-kolom, Anda dapat menggunakan gabungan non-persamaan untuk menentukan apakah item yang dikirim berada di antara rentang minimum dan maksimum dalam kolom. Jika gabungan menemukan rentang yang cocok untuk item tersebut, pengiriman yang sesuai biaya dapat dikembalikan dalam hasil. Seperti metode tradisional persamaan persamaan, gabungan non-persamaan dapat dilakukan dalam klausa WHERE. Selain itu, kata kunci JOIN dapat digunakan dengan klausa ON untuk menentukan kolom yang relevan untuk gabungan.

SELECT E.first_name,
            J.job_hisal,
            J.job_losal,
            E.salary
     FROM employees E JOIN job_sal J
     ON (E.salary BETWEEN J.job_losal AND J.job_losal);

Kita dapat menggunakan semua parameter perbandingan yang telah dibahas sebelumnya seperti operator persamaan dan ketidaksetaraan, ANTARA, IS NULL, IS NOT NULL, dan RELATIONAL.

Gabungan Luar

Gabungan Luar digunakan untuk mengidentifikasi situasi di mana baris dalam satu tabel tidak cocok dengan baris di tabel kedua, meskipun kedua tabel terkait.

Ada tiga jenis gabungan luar: LEFT, RIGHT, dan FULL OUTER JOIN. Semuanya dimulai dengan INNER JOIN, lalu mereka menambahkan kembali beberapa baris yang telah dijatuhkan. A LEFT OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari tabel pertama (kiri) dalam kondisi bergabung, dan kolom keluaran dari tabel kedua (kanan) diatur ke NULL. A RIGHT OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari tabel kedua (kanan) dalam kondisi join, dan kolom output dari tabel pertama (kiri) diatur ke NULL. FULL OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari kedua tabel.

Gabung Luar Kanan

A RIGHT OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari tabel kedua (kanan) dalam kondisi join, dan kolom output dari tabel pertama (kiri) diatur ke NULL. Perhatikan daftar pertanyaan di bawah ini karyawan dan departemen yang sesuai. Juga tidak ada karyawan yang ditugaskan ke departemen 30.

SELECT E.first_name, E.salary, D.department_id          
FROM employees E, departments D
WHERE E.DEPARTMENT_ID (+) = D.DEPARTMENT_ID;

FIRST_NAME SALARY     DEPARTMENT_ID
---------- ---------- ----------
JOHN       6000       10
EDWIN      2000       20
MILLER     2500       10
MARTIN     4000       20
                      30

Gabung Luar Kiri

A LEFT OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari tabel pertama (kiri) dalam kondisi bergabung, dan kolom keluaran dari tabel kedua (kanan) diatur ke NULL. Query yang ditunjukkan di atas dapat digunakan untuk mendemonstrasikan left outer join, dengan menukar posisi tanda (+).

SELECT E.first_name, E.salary, D.department_id
FROM employees E, departments D
WHERE   D.DEPARTMENT_ID = E.DEPARTMENT_ID (+);

FIRST_NAME SALARY     DEPARTMENT_ID
---------- ---------- ----------
JOHN       6000       10
EDWIN      2000       20
MILLER     2500       10
MARTIN     4000       20
                      30

Gabung Luar Penuh

FULL OUTER JOIN menambahkan kembali semua baris yang dijatuhkan dari kedua tabel. Kueri di bawah ini menunjukkan daftar karyawan dan departemen mereka. Perhatikan bahwa karyawan 'MAN' belum ditugaskan ke departemen apa pun hingga sekarang (itu NULL) dan departemen 30 tidak ditugaskan ke karyawan mana pun.

SELECT  nvl (e.first_name,'-') first_name, nvl (to_char (d.department_id),'-') department_id
FROM employee e FULL OUTER JOIN department d
ON e. depARTMENT_ID = d. depARTMENT_ID;

FIRST_NAME DEPARTMENT_ID
---------- --------------------
MAN        -
JOHN       10
EDWIN      20
MILLER     10
MARTIN     20
-          30

6 rows selected.

Produk Cartesian atau Cross join

Untuk dua entitas A dan B, A * B dikenal sebagai produk Cartesian. Produk Cartesian terdiri dari semua kemungkinan kombinasi baris dari setiap tabel. Oleh karena itu, ketika tabel dengan 10 baris digabungkan dengan tabel dengan 20 baris, hasil perkalian Cartesian adalah 200 baris (10 * 20 = 200). Misalnya, menggabungkan tabel karyawan dengan delapan baris dan tabel departemen dengan tiga baris akan menghasilkan tabel produk Cartesian dari 24 baris (8 * 3 = 24).

Gabungan silang mengacu pada produk Kartesius dari dua tabel. Ini menghasilkan produk silang dari dua tabel. Query di atas dapat ditulis menggunakan klausa CROSS JOIN.

Tabel hasil produk Cartesian biasanya tidak terlalu berguna. Faktanya, tabel hasil seperti itu bisa sangat menyesatkan. Jika Anda menjalankan kueri di bawah ini untuk tabel KARYAWAN dan DEPARTEMEN, tabel hasil menunjukkan bahwa setiap karyawan memiliki hubungan dengan setiap departemen, dan kami tahu bahwa ini bukan masalahnya!

SELECT E.first_name, D.DNAME
FROM employees E,departments D;
Bergabung silang dapat ditulis sebagai,
SELECT E.first_name, D.DNAME
FROM employees E CROSS JOIN departments D;