作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
此查询生成每个邮政编码的项目列表。
$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”并查找搜索编码方式中的问题?
最佳答案
您可以使用 OR/AND 运算符优先级来管理它(您的奇怪结果似乎表明您实际上是错误使用运算符优先级的“受害者”),或者只是添加括号。
...
AND (zip IN ($ziparrayimplode) OR all_zip=$allzip)
ORDER BY...
关于php - MySQL 查询问题 - WHERE AND/OR,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14856627/
我是一名优秀的程序员,十分优秀!