我有一个wordpress插件,它本质上是创建一个mysql查询并将结果返回给wordpress。
它是用户驱动的,因此可以在具有多个NOT LIKEs的大型查询中结束,从而导致查询非常慢。
我可以用来改进的任何建议:
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插件中添加了许多负面关键字,这导致了比上面的查询更大的查询。
发布于 2012-03-10 20:34:13
使用REGEXP最容易做到这一点。对于多个单词,使用像(one|two|three)这样的组
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发布于 2012-03-10 20:29:30
您可以使用REGEXP操作一次比较所有模式。
您的查询将如下所示:
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,60https://stackoverflow.com/questions/9646373
复制相似问题