首頁 > 後端開發 > php教程 > 如何在 PHP 中動態綁定參數到 MySQL 查詢?

如何在 PHP 中動態綁定參數到 MySQL 查詢?

Linda Hamilton
發布: 2024-12-03 01:00:14
原創
1017 人瀏覽過

How Can I Dynamically Bind Parameters to MySQL Queries in PHP?

在PHP 中動態綁定MySQL 參數

在您的應用程式中,您會遇到需要將參數動態綁定到準備好的SQL 查詢的場景。雖然您目前的方法有效,但它缺乏多功能性,特別是在處理不同數量的參數時。

為了實現所需的靈活性,您可以使用call_user_func_array() 和解包運算符(...$ var):

public function get_custom_result($sql, $types = null, $params = null) {
    $stmt = $this->mysqli->prepare($sql);
    $stmt->bind_param($types, ...$params);

    if (!$stmt->execute()) return false;
    return $stmt->get_result();
}
登入後複製

這個更新的get_custom_result() 方法允許您透過$types 和$params 動態指定參數類型和值分別為參數。 ...$params 語法解壓縮數組,將每個值單獨傳遞給 bind_param() 方法。

例如,考慮以下查詢和參數值:

$sql = "
SELECT *
FROM root_contacts_cfm
WHERE root_contacts_cfm.cnt_id = ?
AND root_contacts_cfm.cnt_firstname = ?
ORDER BY cnt_id DESC";

$params = ['1', 'Tk'];
登入後複製

您可以現在使用動態參數綁定執行查詢:

$res = $output->get_custom_result($sql, 'ss', $params);

while ($row = $res->fetch_assoc()) {
    echo $row['fieldName'] .'<br>';
}
登入後複製

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

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