首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >一个mysql查询中的like和not like

一个mysql查询中的like和not like
EN

Stack Overflow用户
提问于 2009-06-15 12:59:34
回答 3查看 76.3K关注 0票数 21

我想做一个包含“like”和“not like”的查询。

当前示例:我希望所有内容都以'1|%‘开头,但不要以'1|6|199|%’或'1|6|200|%‘开头。

当前查询:

代码语言:javascript
复制
'SELECT * FROM `links` WHERE `category` LIKE '1|%' NOT LIKE '1|6|199|%','1|6|200|%' ORDER BY `score` DESC LIMIT 9'.

但这并不管用。有什么建议吗?thx

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-06-15 13:00:45

只需添加“和类别”...

代码语言:javascript
复制
SELECT * FROM links 
WHERE category LIKE '1|%' 
  AND category NOT LIKE '1|6|199|%','1|6|200|%' 
ORDER BY score DESC LIMIT 9

实际上,逗号分隔条件不是我熟悉的语法。如果这不起作用,请尝试这样做:

代码语言:javascript
复制
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
票数 35
EN

Stack Overflow用户

发布于 2009-06-15 13:05:10

您可以使用regexps

代码语言:javascript
复制
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的将对结果进行精细过滤。

票数 2
EN

Stack Overflow用户

发布于 2009-06-15 15:42:59

我认为一个更大的问题是你有反规范化的表。正确的答案应该是规范化您的表。

但是如果你不能做到这一点,你应该使用逗号作为分隔符,并使用FIND_IN_SET()

代码语言:javascript
复制
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
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/995971

复制
相关文章

相似问题

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