首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL -优化OR语句

MySQL -优化OR语句
EN

Stack Overflow用户
提问于 2013-01-24 03:50:05
回答 2查看 177关注 0票数 1

我想使用OR子句搜索3列。我知道我遗漏了一些东西,但我一直收到mysql错误。

这是我到目前为止所知道的:

代码语言:javascript
复制
SELECT customerid,companyname,firstname,lastname
FROM `tbl_customers` 
WHERE customeronoff = 1 
AND customerrecordtype = 'A' 
AND (companyname LIKE '$query%') OR (lastname LIKE '$query%') OR (firstname LIKE '$query%')   
ORDER BY lastname ASC

我一定是把手术室放错了。有人能治好我吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-01-24 03:51:11

使用paranethesis对您的OR staements进行分组:

代码语言:javascript
复制
AND (
     (companyname LIKE '$query%') 
  OR (lastname LIKE '$query%') 
  OR (firstname LIKE '$query%')  
)
票数 3
EN

Stack Overflow用户

发布于 2013-01-24 03:52:12

你遗漏了两个括号:

代码语言:javascript
复制
SELECT customerid,companyname,firstname,lastname
FROM `tbl_customers` 
WHERE customeronoff = 1 
AND customerrecordtype = 'A' 
AND **(**(companyname LIKE '$query%') OR (lastname LIKE '$query%') OR (firstname LIKE '$query%')**)**
ORDER BY lastname ASC
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14488144

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档