首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql多个或不喜欢

mysql多个或不喜欢
EN

Stack Overflow用户
提问于 2012-03-10 20:21:49
回答 2查看 2.8K关注 0票数 3

我有一个wordpress插件,它本质上是创建一个mysql查询并将结果返回给wordpress。

它是用户驱动的,因此可以在具有多个NOT LIKEs的大型查询中结束,从而导致查询非常慢。

我可以用来改进的任何建议:

代码语言:javascript
复制
SELECT field1,field2,field3,field4 
from datatable 
WHERE (title NOT LIKE '%word%' AND title NOT LIKE '%word2%'
AND title NOT LIKE '%word3%' AND title NOT LIKE '%word4%' 
AND title NOT LIKE '%word5%' AND title NOT LIKE '%word6%' 
AND title NOT LIKE '%word7%' AND title NOT LIKE '%word8%' 
AND title NOT LIKE '%word9%') 
AND MATCH (title) AGAINST ("\"brandname\" " IN BOOLEAN MODE) 
ORDER BY total ASC LIMIT 0,60

客户在wordpress插件中添加了许多负面关键字,这导致了比上面的查询更大的查询。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-03-10 20:34:13

使用REGEXP最容易做到这一点。对于多个单词,使用像(one|two|three)这样的组

代码语言:javascript
复制
SELECT 
  field1,
  field2,
  field3,
  field4
from datatable
WHERE 
  title NOT REGEXP '(word1|word2|word3|word4|word5...|word9)'
  AND MATCH (title) AGAINST ("\"brandname\" " IN BOOLEAN MODE)
ORDER BY total ASC
LIMIT 0,60
票数 5
EN

Stack Overflow用户

发布于 2012-03-10 20:29:30

您可以使用REGEXP操作一次比较所有模式。

您的查询将如下所示:

代码语言:javascript
复制
SELECT field1,field2,field3,field4 
  FROM data table
 WHERE title NOT REGEXP '^word[0-9]?$'
   AND MATCH(title) ("\"brandname\" " IN BOOLEAN MODE)
 ORDER BY total ASC LIMIT 0,60
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9646373

复制
相关文章

相似问题

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