Cukup kaget awalnya dengan materi ini, secara saya pribadi baru kali ini mendengar istilah INTERSECT dan EXCEPT di mysql. Karna memang selama ini saya merasa belum pernah menggunakan fungsi tersebut, untuk UNION sendiri sudah tidaklah asing mungkin. Maksud dari INTERSECT ini merupakan sebuan fungsi yang berguna untuk menampilkan irisan dari dua tabel atau lebih. Lalu untuk EXCEPT, dari namanya sudah ketahuan, tanpa saya kasih tahu pun sudah dapat tahu apa maksudnya. Singkatnya untuk EXCEPT ini mirip seperti logika NOT IN atau mungkin fungsi LEFT JOIN. Cara penggunaan dan syarat penggunaan fungsi INTERSECT dan EXCEPT mirip seperti UNION, dimana salah satu syaratnya ialah, jumlah dan nama field harus sama. Misal kita punya tabel dengan nama mahasiswa dimana tabel tersebut memiliki field nama, alamat dan kelas. Maka ketika kita akan mengunakan fungsi UNION, EXCEPT, atau pun INTERSECT, tabel lawannya harus memiliki jumlah dan nama field yang sama seperti tabel mahasiswa. Tapi jika kamu coba menggunakan fungsi EXCEPT atau INTERSECT di mysql itu tidak akan berfungsi, kenapa? Alasannya karena fungsi EXCEPT dan INTERSECT itu bukan fungsi murni dari mysql, karna memang fungsi itu tidak ada di mysql. Tapi kamu tak perlu kwatir, disini saya punya query alternatif untuk masalah fungsi INTERSECT atau pun EXCEPT. ALTERNATIF INTERSECT Inti dari fungsi inteersect ini, seperti yang sudah saya katakan tadi, yaitu untuk menampilkan irisan, dimana data yang sama atau cocok saja yang akan di tampilkan. Pada kasus ini kamu bisa menggunakan kombinasi INNER JOIN dan DISTINCT. Disini saya punya tabel dengan nama mahasiswa dengan field :
Lalu untuk tabel keduanya adalah table siswa dengan filed :
Jika mengacu pada kedua tabel di atas, maka untuk query INTERSECT-nya kurang lebih seperti ini :
Kamu bisa mengotak-ngati sesuai yang kamu inginkan, namun kuncinya disini ada di DISTINCT dan INNER JOIN. ALTERNATIF EXCEPT Pada EXCEPT ini kita masih menggunakan tabel yang di pakai di pembahasan INTERSECT, yaitu tabel mahasiswa dan siswa. Jika mengacu pada kedua tabel tersebut maka untuk alternatif query EXCEPT-nya kurang lebih seperti ini : Versi NOT IN
Versi LEFT JOIN
Kurang lebih seperti itu, semoga kamu dapat memahaminya, dan bermanfaat ilmunya. Jadi intinya, seperti yang sudah saya katakan di awal, kalau fungsi INTERSECT dan EXCEPT itu tidak ada di MYSQL. Mungkin pembahasan kali ini saya cukupkan sampai disini dulu, saya pamit undur diri, terima kasih. Tschuss... Tutorial MySQL ini menjelaskan Cara Menggunakan Operator MySQL INTERSECT dengan sintaks dan contoh. DeskripsiFungsi Operator MySQL INTERSECT adalah Meskipun tidak ada operator INTERSECT di MySQL, teman-teman dapat dengan mudah mensimulasikan jenis query ini menggunakan klausa IN atau klausa EXISTS, tergantung pada kompleksitas permintaan INTERSECT. Pertama, mari kita jelaskan apa itu query INTERSECT. Permintaan INTERSECT mengembalikan persimpangan 2 atau lebih kumpulan data. Jika sebuah record ada di kedua kumpulan data, maka akan disertakan dalam hasil INTERSECT. Namun, jika sebuah record ada dalam satu kumpulan data dan tidak di sisi lain, maka akan dihilangkan dari hasil INTERSECT. Contoh INTERSECT Query Penjelasan: Permintaan INTERSECT akan mengembalikan catatan di area yang berwarna biru. Ini adalah catatan yang ada di Dataset1 dan Dataset2. SyntaxSintaks untuk operator MySQL INTERSECT adalah:
Penjelasan Parameterexpression1, expression2, … expression_nKolom atau perhitungan yang ingin Anda ambil kembali.tablesTabel yang ingin Anda ambil dari arsip. Paling tidak ada satu tabel yang tercantum dalam klausa FROM.WHERE conditionsPilihan. Kondisi yang harus dipenuhi agar catatan bisa dipilih.Catatan
Contoh – dengan Single ExpressionPertama, mari jelajahi cara mensimulasikan permintaan operator MySQL INTERSECT yang memiliki satu bidang dengan tipe data yang sama. Jika database mendukung operator INTERSECT (yang tidak MySQL), ini adalah bagaimana Anda akan menggunakan operator MySQL INTERSECT untuk mengembalikan nilai category_id yang umum di antara tabel products dan inventory.
Karena teman-teman tidak dapat menggunakan operator INTERSECT di MySQL, teman-teman akan menggunakan operator IN untuk mensimulasikan permintaan operator MySQL INTERSECT sebagai berikut:
Dalam contoh sederhana ini, teman-teman dapat menggunakan operator IN untuk mengembalikan semua nilai category_id yang ada di tabel products dan inventory. Sekarang, mari kita mempersulit contoh kita lebih jauh dengan menambahkan kondisi WHERE ke query operator MySQL INTERSECT. Sebagai contoh, ini adalah bagaimana operator MySQL INTERSECT akan terlihat dengan kondisi WHERE:
Ini adalah bagaimana teman-teman akan mensimulasikan permintaan operator MySQL INTERSECT menggunakan operator IN dan memasukkan kondisi WHERE:
Dalam contoh ini, klausa WHERE telah ditambahkan yang menyaring tabel produk dan juga hasil dari tabel persediaan. Contoh – dengan Multiple ExpressionsSelanjutnya, mari kita lihat bagaimana mensimulasikan operator MySQL INTERSECT yang menghasilkan lebih dari satu kolom. Pertama, inilah bagaimana teman-teman akan menggunakan operator MySQL INTERSECT untuk mengembalikan banyak ekspresi.
Sekali lagi, karena teman-teman tidak dapat menggunakan operator MySQL INTERSECT, teman-teman dapat menggunakan klausa EXISTS dalam situasi yang lebih kompleks untuk mensimulasikan permintaan operator MySQL INTERSECT sebagai berikut:
Dalam contoh yang lebih kompleks ini, teman-teman dapat menggunakan klausa EXISTS untuk mengembalikan banyak ekspresi yang ada di kedua tabel contacts dimana contact_id kurang dari 100 serta tabel customers dimana last_name tidak sama dengan Heidi. Karena teman-teman sedang melakukan operator MySQL INTERSECT, teman-teman perlu bergabung dengan bidang berpotongan sebagai berikut:
Join disiini dilakukan untuk memastikan bahwa bidang customer_id, last_name, dan first_name dari tabel pelanggan berpotongan dengan bidang contact_id, last_name, dan first_name dari tabel kontak. |