此查询生成每个邮政编码的项目列表。
$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”并查找搜索编码方式中的问题?
答案 0 :(得分:2)
您可以使用OR / AND运算符优先级来管理它(您的奇怪结果似乎表明您实际上是错误使用运算符优先级的“受害者”),或者只是添加括号。
...
AND (zip IN ($ziparrayimplode) OR all_zip=$allzip)
ORDER BY...