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

→ 1320 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

  • Geblek Pari Nanggulan: Menikmati Masakan Rumahan di Tengah Persawahan
  • Warung Makan Purnama Muntilan Sejak 1965
  • Pendakian Gunung Manglayang 1818 MDPL
  • Sate Kambing Moro Lego Pak Kuwat Tulungagung Sejak 1992
  • Kehidupan Tidak Pernah Berakhir
  • Ayam Goreng Tojoyo 3 Sejak 1983
  • Rumah Makan Padang Djawa Magelang
  • Nasi Becek Pojok Nganjuk Sejak 1950
  • Honinbo Shusaku
  • Warung Makan Bu Darmo Muntilan Sejak 1920

Recent Posts

  • Sakopi Magelang: Tempat Nongkrong Asik di Kota Sejuta Bunga
  • Bajak Laut Muntilan Fresh Seafood
  • Geblek Pari Nanggulan: Menikmati Masakan Rumahan di Tengah Persawahan
  • Rumah Makan Padang Djawa Magelang
  • Dapoer Gending Muntilan: Cita Rasa Autentik di Kota Muntilan

Categories

Archives

Subscribe

Enter your email address to subscribe to this blog.

Join 1,225 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

  • Sakopi Magelang: Tempat Nongkrong Asik di Kota Sejuta BungaAugust 19, 2025
  • Bajak Laut Muntilan Fresh SeafoodAugust 17, 2025
  • Geblek Pari Nanggulan: Menikmati Masakan Rumahan di Tengah PersawahanJuly 12, 2025
  • Rumah Makan Padang Djawa MagelangJune 14, 2025
  • Dapoer Gending Muntilan: Cita Rasa Autentik di Kota MuntilanMay 13, 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...