Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mensimulasikan Keadaan 'DAN' Dengan Cekap Merentas Berbilang Baris dalam SQL Tanpa Subqueries?
Kaedah tradisional menapis data menggunakan berbilang pernyataan bersyarat melalui subkueri bersarang boleh menjadi tidak cekap dan kompleks , terutamanya apabila berurusan dengan set data yang besar. Artikel ini meneroka pendekatan alternatif untuk mensimulasikan operasi "DAN" ke atas berbilang baris tanpa menggunakan subkueri.
Pertimbangkan jadual "tag" dengan lajur "tagid" dan "contentid", di mana setiap baris mewakili teg yang ditetapkan kepada sekeping kandungan. Matlamatnya ialah untuk mendapatkan semula "contentid" kandungan yang ditag dengan ID teg tertentu, seperti 334, 338 dan 342.
Pendekatan subkueri konvensional akan melibatkan satu siri pertanyaan bersarang, seperti yang ditunjukkan dalam pseudokod di bawah :
select contentid from tags where tagid = 334 and contentid in ( select contentid from tags where tagid = 338 and contentid in ( select contentid from tags where tagid = 342 ) )
Walau bagaimanapun, kaedah ini berskala buruk dengan peningkatan bilangan ID teg. Untuk menangani pengehadan ini, kami membentangkan penyelesaian yang dioptimumkan yang menggunakan klausa "KUMPULAN OLEH" dan "MENDAPAT":
SELECT contentID FROM tags WHERE tagID in (334, 338, 342) GROUP BY contentID HAVING COUNT(DISTINCT tagID) = 3 --In general SELECT contentID FROM tags WHERE tagID in (...) --taglist GROUP BY contentID HAVING COUNT(DISTINCT tagID) = ... --tagcount
Pertanyaan ini menapis jadual "teg" dengan cekap untuk baris dengan ID teg yang ditentukan. Ia kemudian mengumpulkan hasil mengikut "contentid" dan menggunakan klausa "HAVING" untuk memastikan setiap "contentid" memenuhi syarat untuk mempunyai kiraan ID teg yang berbeza bersamaan dengan nombor yang diingini (cth., 3 dalam contoh ini).
Dengan menggunakan teknik ini, kami boleh melakukan operasi penapisan logik yang kompleks pada berbilang baris dengan cekap, menjadikannya penyelesaian yang lebih berskala dan berprestasi berbanding dengan subkueri tradisional menghampiri.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mensimulasikan Keadaan 'DAN' Dengan Cekap Merentas Berbilang Baris dalam SQL Tanpa Subqueries?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!