我想做一个包含“like”和“not like”的查询。
当前示例:我希望所有内容都以'1|%‘开头,但不要以'1|6|199|%’或'1|6|200|%‘开头。
当前查询:
'SELECT * FROM `links` WHERE `category` LIKE '1|%' NOT LIKE '1|6|199|%','1|6|200|%' ORDER BY `score` DESC LIMIT 9'.
但这并不管用。有什么建议吗?thx
发布于 2009-06-15 13:00:45
只需添加“和类别”...
SELECT * FROM links
WHERE category LIKE '1|%'
AND category NOT LIKE '1|6|199|%','1|6|200|%'
ORDER BY score DESC LIMIT 9
实际上,逗号分隔条件不是我熟悉的语法。如果这不起作用,请尝试这样做:
SELECT * FROM links
WHERE category LIKE '1|%'
AND category NOT LIKE '1|6|199|%'
AND category NOT LIKE '1|6|200|%'
ORDER BY score DESC LIMIT 9
发布于 2009-06-15 13:05:10
您可以使用regexps
SELECT *
FROM links
WHERE category LIKE '1|%'
AND category NOT REGEXP '^1\\|6\\|(199|200)\\|'
ORDER BY
score DESC
LIMIT 9
注意,REGEXP
不使用索引,而LIKE
使用。
在这个查询中,LIKE '1|%'
将充当使用category
上的索引的粗略过滤器,而REGEXP
的将对结果进行精细过滤。
发布于 2009-06-15 15:42:59
我认为一个更大的问题是你有反规范化的表。正确的答案应该是规范化您的表。
但是如果你不能做到这一点,你应该使用逗号作为分隔符,并使用FIND_IN_SET()
:
WHERE FIND_IN_SET('1', category) > 1
AND FIND_IN_SET('6', category) > 1
AND FIND_IN_SET('199', category) = 0
AND FIND_IN_SET('200', category) = 0
https://stackoverflow.com/questions/995971
复制相似问题