首頁 > 後端開發 > php教程 > 如何在MySQLi查詢中高效綁定多個參數?

如何在MySQLi查詢中高效綁定多個參數?

Mary-Kate Olsen
發布: 2024-12-11 05:26:10
原創
365 人瀏覽過

How Can I Efficiently Bind Multiple Parameters in MySQLi Queries?

MySQLi 查詢中多個參數的靈活綁定

目前,為了將多個參數綁定到MySQLi 查詢中,採用以下重複結構:

if ($words_total == 1)
{
    $statement -> bind_param("s", $words[0]);
}
// ... more if-else conditions for each possible number of parameters ...
登入後複製

要計算查詢中需要的問號數量,以下程式碼使用的是:

$marks = "";
for($i = 1; $i<=$words_total; $i++) {
    if ($i == $words_total)
        $marks .= "?";
    else
        $marks .= "?,";
}
登入後複製

參數拆包的改良方法

幸運的是,PHP 5.6 引入了參數拆包運算子(...),它簡化了多個參數的綁定參數。此運算子可以與陣列一起使用,而不是依賴靜態類型字串:

// create an array of parameter values
$parameters = [$words[0], $words[1], ... $words];

// create a type string dynamically
$types = str_repeat('s', count($parameters));

// bind the array using argument unpacking
$statement -> bind_param($types, ...$parameters);
登入後複製

透過這種方法,無論參數數量如何,都可以動態處理綁定。

以上是如何在MySQLi查詢中高效綁定多個參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板