1

此查询生成每个邮政编码的项目列表。

$ziparrayimplode = implode(",", $ziparray);
        $listingquery = "SELECT * FROM listings WHERE (CONCAT(title, description) LIKE '%".$searchstring."%') AND auc_cat LIKE '%".$category."%' AND zip IN ($ziparrayimplode) AND all_zip=$allzip ORDER BY list_ts DESC $pages->limit";
        $listinghistory = mysql_query($listingquery) or die(mysql_error());

如果我在 all_zip=$allzip 的 WHERE 语句中使用“AND”,那么所有适用于 all_zip 的项目都会显示,但不会显示 $ziparray 中的项目。如果我在 WHERE 语句中使用“OR”,那么 $ziparray 的正确项以及 $allzip 将被包括在内......但我的搜索功能根本不起作用。

我是否正确地表达了这个查询,还是应该在 WHERE 语句中使用“OR”并在搜索编码方式中查找问题?

4

1 回答 1

2

您可以使用 OR / AND 运算符优先级来管理它(您奇怪的结果似乎表明您实际上是错误使用运算符优先级的“受害者”),或者只是添加括号。

...
AND (zip IN ($ziparrayimplode) OR all_zip=$allzip)
ORDER BY...
于 2013-02-13T15:13:22.267 回答