Menggunakan Penyata WHERE IN Dengan Berkesan
Pernyataan WHERE IN adalah penting untuk memadankan rekod berdasarkan set nilai yang ditentukan. Walau bagaimanapun, membinanya dengan betul boleh mencabar.
Jika anda cuba menggunakan:
WHERE obj IN (?)
Anda mungkin menghadapi ralat jika bilangan nilai yang diberikan tidak sepadan dengan bilangan parameter . Untuk menyelesaikannya:
statement = "SELECT * FROM tab WHERE obj IN ({0})".format(', '.join(['?'] * len(list_of_vars))) c.execute(statement, list_of_vars)
Dalam pendekatan ini, kami menjana pernyataan secara dinamik dengan bilangan pemegang tempat parameter yang betul menggunakan '.join()' dan '.format()'.
Sebagai alternatif, untuk pendekatan yang lebih cekap dengan senarai pembolehubah yang besar, pertimbangkan untuk menggunakan jadual sementara. Sertai jadual sementara dengan jadual utama anda dan bukannya menggunakan klausa IN dengan parameter bind. Pengoptimuman ini meningkatkan prestasi dengan mengurangkan bilangan ikatan pangkalan data yang diperlukan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Penyata WHERE IN dengan Berbilang Nilai dengan Berkesan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!