Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Meluluskan Tatasusunan ID kepada Klausa SQL WHERE?
Anda mempunyai pelbagai ID galeri, $galleries dan anda ingin mencipta pertanyaan SQL yang memilih baris daripada jadual pangkalan data berdasarkan nilai dalam tatasusunan.
Untuk mencapai ini, anda perlu menggunakan klausa IN dalam anda keadaan MANA. Klausa ini membolehkan anda menentukan senarai nilai untuk dibandingkan dengan medan. Begini cara anda boleh mengubah suai pertanyaan anda:
SELECT * FROM galleries WHERE id IN (1, 2, 5);
Dengan menggantikan /* nilai tatasusunan $galleries... cth. (1 || 2 || 5) */ dengan nilai sebenar daripada tatasusunan anda, anda boleh menjana klausa IN secara dinamik.
Terdapat beberapa cara untuk melakukan ini dalam PHP:
Kaedah 1: Menggunakan implode():
$ids = implode(',', $galleries); $sql = "SELECT * FROM galleries WHERE id IN ($ids);";
Kaedah 2: Menggunakan Pengikatan parameter PDO:
$stmt = $pdo->prepare("SELECT * FROM galleries WHERE id IN (:ids);"); $stmt->bindParam(':ids', implode(',', $galleries), PDO::PARAM_STR); $stmt->execute();
Dengan menggunakan teknik ini, anda boleh membuat pertanyaan SQL dengan mudah yang menapis data berdasarkan nilai yang disimpan dalam tatasusunan.
Atas ialah kandungan terperinci Bagaimana untuk Meluluskan Tatasusunan ID kepada Klausa SQL WHERE?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!