MySQL查询的麻烦 - WHERE和/或

时间:2013-02-13 15:11:20

标签: php mysql where

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

$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”并查找搜索编码方式中的问题?

1 个答案:

答案 0 :(得分:2)

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

...
AND (zip IN ($ziparrayimplode) OR all_zip=$allzip)
ORDER BY...