首页 > 后端开发 > php教程 > 如何在 WHERE ... IN() 子句中高效地使用数组和 MySQL 准备语句?

如何在 WHERE ... IN() 子句中高效地使用数组和 MySQL 准备语句?

Mary-Kate Olsen
发布: 2024-12-29 04:06:13
原创
307 人浏览过

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

在 MySQL 准备语句中使用数组进行 WHERE ... IN(...) 查询

使用准备语句查询数据库时,建议准备一条语句并多次执行以提高性能。但是,在处理 WHERE ... IN(...) 查询的 ID 数组时,执行后手动对结果进行排序可能效率低下。

另一种方法是利用涉及创建基于数组长度的以逗号分隔的占位符 (?) 列表。考虑以下示例:

1

2

3

4

5

6

7

8

9

10

11

$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中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板