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