Pengikatan Dinamik Berbilang Parameter dalam Pertanyaan mysqli
Secara tradisinya, pembangun PHP telah bergantung pada pernyataan bersyarat yang panjang atau gabungan manual untuk mengikat berbilang parameter ke dalam pertanyaan mysqli. Ini boleh membosankan dan terdedah kepada ralat.
Pengikatan Parameter Kod Keras
Contoh yang anda berikan menunjukkan pendekatan kod keras, di mana bilangan tanda soal dan jenis parameter adalah secara manual diselaraskan berdasarkan bilangan nilai input. Walaupun ini berfungsi, ini bukan penyelesaian yang ideal untuk mengendalikan pertanyaan dinamik.
Operator Membongkar Argumen
Nasib baik, PHP 5.6 memperkenalkan operator pembongkar hujah (...) yang membolehkan kami menghantar tatasusunan sebagai parameter kepada fungsi yang mengharapkan berbilang individu argumen.
Penyelesaian menggunakan Argument Unpacking
Untuk mengikat bilangan parameter secara dinamik dalam PHP 5.6 , kita boleh menggunakan pendekatan berikut:
1. Cipta rentetan jenis: Gabungkan aksara yang sepadan dengan jenis parameter (cth., s untuk rentetan) seberapa banyak yang terdapat parameter.
$types = str_repeat('s', count($array)); // returns sss...
2. Ikat parameter: Gunakan operator pembongkaran argumen untuk menghantar tatasusunan nilai parameter sebagai parameter individu bersama-sama dengan rentetan jenis:
$stmt->bind_param($types, ...$array);
Contoh:
$array = ['a','b','c']; $sql = "SELECT name FROM table WHERE city IN (?,".str_repeat('?,', count($array) - 2).")"; // returns ?,?,?... $stmt = $mysqli->prepare($sql); $stmt->bind_param('s', ...$array); $stmt->execute();
Pendekatan ini dengan elegan mengendalikan sebarang bilangan parameter input tanpa memerlukan pernyataan bersyarat atau penyambungan manual.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengikat Berbilang Parameter Secara Dinamik dalam Pertanyaan mysqli?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!