Skip to content
Arif Setiawan
Arif Setiawan

travel, culinary and technology

  • Home
  • About
  • Travel
    • Indonesia
      • Bali
      • Banten
      • Jakarta
      • Jawa Barat
      • Jawa Tengah
      • Jawa Timur
      • Kalimantan Selatan
      • Lampung
      • Sumatera Barat
      • Sumatera Utara
      • Yogyakarta
    • Laos
    • Malaysia
    • Singapore
    • Vietnam
  • Culinary
  • Technology
    • Startup
    • Software Development
    • Social Media
  • #kulinersince
  • Nol Kilometer
Arif Setiawan

travel, culinary and technology

Konsep SQL Join

Arif Setiawan, April 1, 2014March 14, 2018

Rasa-rasanya sudah lama sekali saya tidak bikin postingan yang sedikit teknis. Kalau ga curhat ya kuliner ya jalanan, heheu. Nah, pagi ini saya melihat postingan Mas Pay di Google+ yang share masalah SQL Join ini.

Kalau masalah database, terutama bagian SQL nya, masalah Join ini kadang bisa jadi salah satu yang bisa bikin bingung. Semacem belajar rekursifnya programming. Iya ga si? Emang beberapa orang bisa lancar dan cepet paham, tapi ada juga beberapa yang tidak, harus banyak latihan dulu. Kayak saya, heheu.

Selain itu, SQL join juga sering banget digunakan untuk bahan interview buat nyari orang yang akan dipekerjakan sebagai DBA (Database Administrator). Kadang disinggung soal perbedaan dari berbagai jenis join yang ada atau simplenya langsung disuruh nulis query yang menandakan operasi join ini.

Dari gambar di postingan ini sudah terlihat kan beberapa jenis operasi join yang ada.

  1. LEFT JOIN
  2. RIGHT JOIN
  3. INNER JOIN
  4. OUTER JOIN
Penjelasannnya pun lebih mudah jika digambarkan sebagai himpunan bagian seperti itu kan? A dan B merupakan nama tabel, sedangkan warna merah menandakan hasil query join terhadap isi tabel.
Perbedaan mendasarnya, INNER JOIN hanya menghasilkan records yang cocok antara kedua tabel, sedangkan OUTER JOIN akan menghasilkan semua records, termasuk yang tidak cocok antara kedua tabel.

Contoh Sederhana

 

mysql> select * from employee;
+——–+———-+———+——–+
| emp_id | emp_name | dept_id | salary |
+——–+———-+———+——–+
|    103 | Jack     |       1 |   1400 |
|    104 | John     |       2 |   1450 |
|    108 | Alan     |       3 |   1150 |
|    107 | Ram      |    NULL |    600 |
+——–+———-+———+——–+
mysql> select * from department;
+———+———–+
| dept_id | dept_name |
+———+———–+
|       1 | Sales     |
|       2 | Finance   |
|       3 | Accounts  |
|       4 | Marketing |
+———+———–+

Dari dua tabel di atas, terlihat bahwa ada nilai NULL pada field dept_id di tabel employee. Menandakan bahwa tidak ada baris yang cocok dengan isi tabel department. Nah, bagaimana hasilnya jika kita melakukan operasi LEFT OUTER JOIN dan RIGHT OUTER JOIN?

mysql> select e.emp_id, e.emp_name, d.dept_name from employee e LEFT JOIN department d on e.dept_id=d.dept_id;
+——–+———-+———–+
| emp_id | emp_name | dept_name |
+——–+———-+———–+
|    103 | Jack     | Sales     |
|    104 | John     | Finance   |
|    108 | Alan     | Accounts  |
|    107 | Ram      | NULL      |
+——–+———-+———–+
mysql> select e.emp_id, e.emp_name, d.dept_name from employee e RIGHT JOIN department d on e.dept_id=d.dept_id;
+——–+———-+———–+
| emp_id | emp_name | dept_name |
+——–+———-+———–+
|    103 | Jack     | Sales     |
|    104 | John     | Finance   |
|    108 | Alan     | Accounts  |
|   NULL | NULL     | Marketing |
+——–+———-+———–+
Jika LEFT JOIN, maka walaupun record valuenya NULL, akan tetap ikut menjadi hasil query dengan nilai NULL, sesuai dengan jumlah baris tabel sebelah kiri. Begitu pula RIGHT JOIN, akan di sesuaikan dengan tabel yang sebelah kanan walaupun ada nilai NULL di tabel kiri.

Paham sekarang? heheu.

@ariffsetiawan

→ 1312 readers

Related

Programming DatabaseSQL

Post navigation

Previous post
Next post

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Popular Posts

  • Game Development Life Cycle
  • Soto Podjok Kediri Sejak 1926
  • Danau Beratan Bedugul Bali
  • Warung Makan Purnama Muntilan Sejak 1965
  • Soto Betawi Haji Ma’ruf Sejak 1940
  • Sate Subali Batang Sejak 1971
  • Pempek Ny. Kamto Sejak 1984
  • Virgin Beach Karangasem Bali
  • Soto Betawi Haji Mamat Sejak 1960
  • Ekstens Coffee and Space Jogja: Lebih dari Sekadar Tempat Ngopi

Recent Posts

  • Rumah Makan Padang Djawa Magelang
  • Dapoer Gending Muntilan: Cita Rasa Autentik di Kota Muntilan
  • Depot Nikmat Jombang Sejak 1987
  • Alun-Alun Jombang: Ruang Publik Ikonik di Jantung Kota Santri
  • Nol Kilometer Tuban: Titik Awal Menjelajah Bumi Wali

Categories

Archives

Subscribe

Enter your email address to subscribe to this blog.

Join 1,224 other subscribers
Seedbacklink

Travel

  • Alun-Alun Jombang: Ruang Publik Ikonik di Jantung Kota SantriMay 4, 2025
  • Nol Kilometer Tuban: Titik Awal Menjelajah Bumi WaliApril 27, 2025
  • Leisure Trip ke Morwell: Dari Taman Bunga hingga Sushi Favorit TravelerMarch 24, 2025
  • Jalan Braga: Simbol Kejayaan Bandung di Masa KolonialJanuary 5, 2025
  • Staycation di Grand Rohan JogjaDecember 25, 2024

Culinary

  • Rumah Makan Padang Djawa MagelangJune 14, 2025
  • Dapoer Gending Muntilan: Cita Rasa Autentik di Kota MuntilanMay 13, 2025
  • Depot Nikmat Jombang Sejak 1987May 10, 2025
  • Sop Buntut dan Soto Pak Sugeng YogyakartaApril 3, 2025
  • Warung Kopi Purnama Bandung: Legenda yang Bertahan Sejak 1930January 4, 2025

Technology

  • iOS Conference Singapore 2020November 28, 2021
  • Sinergi Coworking Space JogjaAugust 22, 2020
  • WordCamp Jakarta 2019February 12, 2020
  • Kubik Coworking & Art Space PadangApril 13, 2019
  • Redesign Aplikasi IndiHomeNovember 6, 2018
©2025 Arif Setiawan | WordPress Theme by SuperbThemes
 

Loading Comments...