首页 > 后端开发 > php教程 > 如何高效地从 MySQL LIKE 查询中获取所有结果?

如何高效地从 MySQL LIKE 查询中获取所有结果?

Linda Hamilton
发布: 2024-12-14 19:27:12
原创
399 人浏览过

How to Efficiently Fetch All Results from a MySQL LIKE Query?

使用 LIKE 和多个结果的 MySQL 查询

在 MySQL 中,在查询中使用 LIKE 运算符通常可以返回多个结果。要检索所有匹配结果,您需要使用正确的获取方法。

获取所有结果

要从查询中获取所有结果,您可以使用 get_result() 方法。此方法以 MySQLi_Result 对象的形式检索完整的结果集。然后,您可以使用 fetch_all() 方法获取所有行数据的数组,如果您使用了 MYSQLI_ASSOC 常量,则通过字段名称关联。

使用 get_result() 的示例代码:

$param = "%{$_POST['user']}%";
$stmt = $db->prepare("SELECT id, username FROM users WHERE username LIKE ?");
$stmt->bind_param("s", $param);
$stmt->execute();
$result = $stmt->get_result();
$data = $result->fetch_all(MYSQLI_ASSOC);
登录后复制

使用 PHP 8.2 的示例代码execute_query():

$sql = "SELECT id, username FROM users WHERE username LIKE ?";
$result = $db->execute_query($sql, ["%{$_POST['user']}%"]);
$data = $result->fetch_all(MYSQLI_ASSOC);
登录后复制

迭代获取

如果您喜欢迭代获取结果,可以使用 fetch() 方法。但是,您需要自己处理迭代,因为没有内置的方法来循环所有结果。

使用bind_result()迭代获取的示例代码:

$param = "%{$_POST['user']}%";
$stmt = $db->prepare("SELECT id, username FROM users WHERE username LIKE ?");
$stmt->bind_param("s", $param);
$stmt->execute();

$stmt->bind_result($id, $username);
while ($stmt->fetch()) {
  echo "Id: {$id}, Username: {$username}";
}
登录后复制

请记住始终参考 MySQLi 文档以获取有关获取的最新信息结果。

以上是如何高效地从 MySQL LIKE 查询中获取所有结果?的详细内容。更多信息请关注PHP中文网其他相关文章!

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