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

→ 1339 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
  • Nasi Ayam Kedewatan Ibu Mangku Sejak 1964
  • Pempek Ny. Kamto Sejak 1984
  • Rumah Makan Adem Ayem Solo Sejak 1969
  • Danau Beratan Bedugul Bali
  • Ayam Goreng Bu Tini Sejak 1967
  • Sate Sapi Pak Kempleng Ungaran Sejak 1960
  • Sate Kambing Moro Lego Pak Kuwat Tulungagung Sejak 1992
  • Sate Subali Batang Sejak 1971
  • Danau Ciharus, Ranu Kumbolonya Jawa Barat

Recent Posts

  • Kota Lama: Wisata Sejarah Ikonik di Semarang
  • Mencegah Website Down saat Flash Sale dan Lonjakan Traffic
  • Hosting Terbaik 2026 untuk Website Pribadi, Portofolio, dan Startup
  • Loko Cafe Stasiun Tugu Yogyakarta
  • Steak Holycow CAMP Jogja

Categories

Archives

Subscribe

Enter your email address to subscribe to this blog.

Travel

  • Kota Lama: Wisata Sejarah Ikonik di SemarangMarch 7, 2026
  • Loko Cafe Stasiun Tugu YogyakartaJanuary 31, 2026
  • Universal Studios Singapore: Panduan Wahana, Tips, dan Akses LengkapDecember 1, 2025
  • Pantai Batu Bolong Canggu BaliNovember 26, 2025
  • Tanah Lot: Keindahan Alam dan Spiritualitas yang Menyatu di BaliNovember 24, 2025

Culinary

  • Steak Holycow CAMP JogjaJanuary 1, 2026
  • Soto Sapi Mbah Marto Sawitan MagelangDecember 28, 2025
  • Bebek Bacem Seyegan Sleman YogyakartaDecember 21, 2025
  • Raja Kosek Resto Mungkid MagelangDecember 20, 2025
  • Kazu Ramen: Pilihan Kuliner Ramen di Barat YogyakartaDecember 14, 2025

Technology

  • Mencegah Website Down saat Flash Sale dan Lonjakan TrafficFebruary 18, 2026
  • Hosting Terbaik 2026 untuk Website Pribadi, Portofolio, dan StartupFebruary 8, 2026
  • Nevacloud vs Hostinger VPS Global: Pilihan Terbaik untuk Pengguna IndonesiaDecember 13, 2025
  • Apa Bedanya VPS dengan Hosting BiasaDecember 5, 2025
  • Perbedaan Domain .COM, .ID, dan .NETNovember 5, 2025
©2026 Arif Setiawan | WordPress Theme by SuperbThemes
 

Loading Comments...