>我有一个HTML输入字段,其中的值被分解并用字符串中的每个空格分隔。然后,此字符串在数据库中搜索匹配项,如果存在匹配项,则返回值,但是我想从原始字符串中搜索一个表中的多个字段。
希望这将澄清问题:
例如,如果用户搜索"谢尔顿男孩跳线",我希望数据库在数据库的每个字段中搜索匹配的每个关键字,例如 [school_name]、[]、[product_type]。目前,我将其用于一个字段,但我想返回并收集所有三个字段的值。
这是我的代码:
if (empty($_POST) === false) {
if(empty($_POST['title']) === true) {
$no_data = '<div class="alert alert-danger center">Please enter a title</div>';
} else {
$item_title = $_POST['title'];
$keywords = explode(" ", $item_title);
$query = "SELECT * FROM products WHERE ";
foreach($keywords as $keyword) {
$i++; // dump variable
if($i == 1) { $query .= "product LIKE '$keyword' "; }
else { $query .= "OR product LIKE '$keyword' "; }
}
$query = mysql_query($query);
$numrows = mysql_num_rows($query);
$row = mysql_fetch_assoc($query);
echo $row['product'];
}
}
为了安全和方便,您确实希望使用PDO。无论哪种方式,您仍然需要准备一份声明。
$fields = array('fields','you','want','to','search');
foreach($keywords as $keyword) {
foreach ($fields as $field) {
$i++; // dump variable
if($i == 1) {
$query .= "$field LIKE '$keyword' ";
} else {
$query .= "OR $field LIKE '$keyword' ";
}
}
$i == 1 为弱真。您可以设置 $i = false,然后设置 if($i === true),省去为每个循环递增变量的麻烦。或者,在每行的末尾都有 OR,而不是开头,以及最终查询字符串中 OR 的最后一个实例。这也会从每个循环中删除 if。
$fields = array('fields','you','want','to','search');
foreach($keywords as $keyword) {
foreach ($fields as $field) {
$query .= "$field LIKE '$keyword' OR ";
}
}
$query = substr($query, 0, strlen($query) - 4);