Rumah > pembangunan bahagian belakang > tutorial php > Bagaimana untuk Mengikat Susunan Rentetan dengan Cekap pada Klausa IN Penyata Disediakan MySQLi?

Bagaimana untuk Mengikat Susunan Rentetan dengan Cekap pada Klausa IN Penyata Disediakan MySQLi?

Mary-Kate Olsen
Lepaskan: 2024-12-24 15:50:11
asal
526 orang telah melayarinya

How to Efficiently Bind an Array of Strings to a MySQLi Prepared Statement's IN Clause?

Mengikat Susunan Rentetan dalam Penyata Disediakan MySQLi untuk Klausa IN

Dalam bidang interaksi pangkalan data, mungkin timbul situasi di mana anda memerlukan mengikat tatasusunan nilai rentetan ke klausa WHERE IN (?) dalam pernyataan yang disediakan MySQLi. Artikel ini menyelidiki prinsip asas dan menyediakan penyelesaian yang elegan, terutamanya memfokuskan pada PHP versi 8.2, 8.1 dan versi terdahulu.

PHP 8.2: Pendekatan Ringkas

The fungsi execute_query(), yang diperkenalkan dalam PHP 8.2, menyelaraskan proses pelaksanaan yang disediakan pernyataan dengan tatasusunan yang diisi data. Contohnya:

$sql = "SELECT name FROM table WHERE city IN (?,?)";
$array = ["Nashville", "Knoxville"];
$result = $mysqli->execute_query($sql, $array);
Salin selepas log masuk

Untuk kes yang melibatkan kiraan ruang letak dinamik, anda boleh menggunakan str_repeat() untuk membina ruang letak secara dinamik:

$array = ["Nashville", "Knoxville"];
$parameters = str_repeat("?,", count($array) - 1) . "?";
$sql = "SELECT name FROM table WHERE city IN ($parameters)";
$result = $mysqli->execute_query($sql, $array);
Salin selepas log masuk

PHP 8.1: Pelaksanaan Tatasusunan Terus

Dalam PHP 8.1 dan ke atas, anda boleh laksanakan pernyataan yang disediakan dengan tatasusunan secara langsung, menghilangkan keperluan untuk pengikatan eksplisit:

$sql = "SELECT name FROM table WHERE city IN (?,?)";
$stmt = $mysqli->prepare($sql);
$stmt->execute(["Nashville", "Knoxville"]);
$result = $stmt->get_result();
Salin selepas log masuk

Versi Terdahulu: Merangkul Kerumitan

Untuk versi sebelum PHP 8.1, prosedurnya agak lebih rumit:

  • Buat rentetan ruang letak dengan bilangan tanda soal yang sama seperti elemen dalam tatasusunan menggunakan str_repeat().
  • Tambah rentetan ruang letak ini pada pertanyaan.
  • Sediakan pertanyaan secara tradisional.
  • Bina a taip rentetan untuk bind_param() menggunakan str_repeat(), biasanya menggunakan "s" untuk rentetan.
  • Gunakan operator pembongkar hujah (...) untuk mengikat nilai tatasusunan secara beramai-ramai.
  • Laksanakan pertanyaan dan dapatkan semula hasilnya.

Contoh:

$array = ["Nashville", "Knoxville"];
$in = str_repeat("?,", count($array) - 1) . "?";
$sql = "SELECT name FROM table WHERE city IN ($in)";
$stmt = $mysqli->prepare($sql);
$types = str_repeat("s", count($array));
$stmt->bind_param($types, ...$array);
$stmt->execute();
$result = $stmt->get_result();
Salin selepas log masuk

Walaupun lebih bertele-tele, kod ini menawarkan penyelesaian ringkas berbanding pendekatan alternatif.

Sebagai kesimpulan, mengikat tatasusunan rentetan kepada klausa IN dalam pernyataan yang disediakan MySQLi melibatkan beberapa kaedah yang disesuaikan dengan versi PHP yang berbeza. Dengan memanfaatkan teknik yang diterangkan dalam artikel ini, anda boleh melaksanakan pertanyaan ini dengan berkesan dalam interaksi pangkalan data anda.

Atas ialah kandungan terperinci Bagaimana untuk Mengikat Susunan Rentetan dengan Cekap pada Klausa IN Penyata Disediakan MySQLi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan