首頁 > 後端開發 > php教程 > 如何在 WHERE ... IN() 子句中高效率地使用陣列和 MySQL 準備語句?

如何在 WHERE ... IN() 子句中高效率地使用陣列和 MySQL 準備語句?

Mary-Kate Olsen
發布: 2024-12-29 04:06:13
原創
196 人瀏覽過

How Can I Efficiently Use Arrays with MySQL Prepared Statements in WHERE ... IN() Clauses?

在MySQL 準備語句中使用陣列進行WHERE ... IN(...) 查詢

使用準備語句查詢資料庫時,建議準備一條語句並多次執行以提高效能。但是,在處理 WHERE ... IN(...) 查詢的 ID 陣列時,執行後手動對結果進行排序可能會效率低下。

另一種方法是利用涉及創建基於數組長度的以逗號分隔的佔位符 (?) 列表。考慮以下範例:

$ids = array(1,5,18,25);

// Create a string containing ?,?,?
$clause = implode(',', array_fill(0, count($ids), '?'));

$stmt = $mysqli->prepare('SELECT * FROM somewhere WHERE `id` IN (' . $clause . ') ORDER BY `name`;');

call_user_func_array(array($stmt, 'bind_param'), $ids);
$stmt->execute();

// Loop through results
登入後複製

在此方法中,implode(...) 建立一個具有所需數量佔位符的字串。然後,call_user_func_array(...) 函數將 $ids 陣列中的值綁定到佔位符。透過使用這種技術,您可以使用 MySQL 內建的排序功能對結果進行排序,從而無需手動排序。

以上是如何在 WHERE ... IN() 子句中高效率地使用陣列和 MySQL 準備語句?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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