首页 > 解决方案 > 使用用户文本输入搜索数据库时出现 PHP 'mysqli_query' 的问题

问题描述

我正在尝试根据文本输入查询我的数据库以选择。如果我手动输入字符串,它会正确查询并返回预期的行。但是,如果我使用存储字符串的变量,它将不会从我的数据库中返回任何行。有人可以看看这段代码并分享关于这个问题的任何想法吗?我很抱歉,但我是 PHP 新手,我只是想让一个简单的评论表正确显示。

我有一个搜索输入,用户以这种格式输入搜索:“姓名、地址、城市、州”。我使用explode() 函数将输入拆分为每个组件,并分别命名为$name、$address、$city、$state。我包括了一切停止工作的代码。

$searchWords = explode(",", $text);
$address = $searchWords[1];
$name = $searchWords[0];
$city = $searchWords[2];
$state = $searchWords[3];

当我在每个变量上回显 gettype() 时,结果是“字符串”并且预期的字符串会打印到屏幕上。这是我遇到问题的代码:

$display = mysqli_query($conn, "SELECT * FROM reviews WHERE address1 LIKE '%$address%'");

如果我手动设置 $address = '123 Pokemon St' 或任何字符串,然后在查询中使用 $address,它就可以正常工作。但是,如果我在最初定义它之后尝试使用 $address,它将不起作用。我尝试将每个值类型转换为字符串,但这不起作用。

我知道我可以在 PHP 文档的某个地方找到这些信息,但我已经花了几个小时搜索它,但无济于事。我今天需要完成我的项目,所以非常感谢任何帮助:)

标签: phpphpmyadmin

解决方案


我认为你的问题是空格。因为格式是

name, address, city, state

这将导致这些值

// example of $text = "Donnie, Pokemon Street, Denver, Colorado"
$searchWords = explode(",", $text);
$address = $searchWords[1] // "Donnie";
$name = $searchWords[0]; // " Pokemon Street"
$city = $searchWords[2]; // " Denver"
$state = $searchWords[3]; // " Colorado"

您可以尝试在将分解的值传递给查询之前对其进行修剪吗?

$address = trim($searchWords[1]); // "Donnie"
$name = trim($searchWords[0]); // "Pokemon Street"
$city = trim($searchWords[2]); // "Denver"
$state = trim($searchWords[3]); // "Colorado"

希望这可以帮助!


推荐阅读