繁体   English   中英

查询不符合多个条件

[英]Query is not matching multiple conditions

以为这个MySQL查询正在运行并且正在返回结果,但是它忽略了这一位:wherepublished ='1'部分并显示所有结果,而不管发布值是多少。

我认为这与在查询的某些位周围使用方括号有关,但已尝试了多种方式,但似乎无法正确处理。

这是我目前的查询方式:

SELECT * 
FROM news 
WHERE published='1' 
  AND title LIKE '%$q%' 
   OR details LIKE '%$q%'
ORDER BY id DESC

任何帮助表示赞赏!

您应该应用显式括号:

SELECT * 
FROM news 
WHERE published='1'
  AND (title LIKE '%$q%' OR details LIKE '%$q%')
ORDER BY id DESC

在带有隐式括号的示例中,它的工作方式如下:

WHERE (published='1' AND title LIKE '%$q%')
   OR details LIKE '%$q%'

因为and具有比or更高的评估优先级。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM