SQL - Menggunakan Gabungan

SQL Joinsklausa digunakan untuk menggabungkan rekaman dari dua atau lebih tabel dalam database. JOIN adalah cara untuk menggabungkan bidang dari dua tabel dengan menggunakan nilai yang sama untuk masing-masing.

Pertimbangkan dua tabel berikut -

Table 1 - Meja PELANGGAN

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

Table 2 - Tabel ORDERS

+-----+---------------------+-------------+--------+
|OID  | DATE                | CUSTOMER_ID | AMOUNT |
+-----+---------------------+-------------+--------+
| 102 | 2009-10-08 00:00:00 |           3 |   3000 |
| 100 | 2009-10-08 00:00:00 |           3 |   1500 |
| 101 | 2009-11-20 00:00:00 |           2 |   1560 |
| 103 | 2008-05-20 00:00:00 |           4 |   2060 |
+-----+---------------------+-------------+--------+

Sekarang, mari kita gabungkan dua tabel ini dalam pernyataan SELECT kita seperti yang ditunjukkan di bawah ini.

SQL> SELECT ID, NAME, AGE, AMOUNT
   FROM CUSTOMERS, ORDERS
   WHERE  CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

Ini akan menghasilkan hasil sebagai berikut.

+----+----------+-----+--------+
| ID | NAME     | AGE | AMOUNT |
+----+----------+-----+--------+
|  3 | kaushik  |  23 |   3000 |
|  3 | kaushik  |  23 |   1500 |
|  2 | Khilan   |  25 |   1560 |
|  4 | Chaitali |  25 |   2060 |
+----+----------+-----+--------+

Di sini, terlihat bahwa penggabungan dilakukan di klausa WHERE. Beberapa operator dapat digunakan untuk menggabungkan tabel, seperti =, <,>, <>, <=,> =,! =, ANTARA, SUKA, dan BUKAN; semuanya dapat digunakan untuk menggabungkan tabel. Namun, operator yang paling umum adalah simbol sama dengan.

Ada berbagai jenis gabungan yang tersedia di SQL -

  • INNER JOIN - mengembalikan baris jika ada kecocokan di kedua tabel.

  • LEFT JOIN - mengembalikan semua baris dari tabel kiri, meskipun tidak ada kecocokan di tabel kanan.

  • RIGHT JOIN - mengembalikan semua baris dari tabel kanan, meskipun tidak ada kecocokan di tabel kiri.

  • FULL JOIN - mengembalikan baris ketika ada kecocokan di salah satu tabel.

  • SELF JOIN - digunakan untuk menggabungkan tabel ke tabel itu sendiri seolah-olah tabel adalah dua tabel, untuk sementara mengganti nama setidaknya satu tabel dalam pernyataan SQL.

  • CARTESIAN JOIN - mengembalikan produk Cartesian dari kumpulan record dari dua atau lebih tabel yang digabungkan.

Sekarang mari kita bahas masing-masing gabungan ini secara rinci.