首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将“LIKE”与充满字符串的“IN”子句一起使用

将“LIKE”与充满字符串的“IN”子句一起使用
EN

Stack Overflow用户
提问于 2011-04-06 01:59:30
回答 6查看 27K关注 0票数 7

我想在表中做一个软字符串匹配,如下所示:

代码语言:javascript
复制
SELECT * FROM emailaddresses where addr in ('john@google.com', 'jim@google.com')

但是,如果表'JOHN@google.com‘中有addr值,我希望返回该值。

有点像这样:

代码语言:javascript
复制
SELECT * FROM emailaddresses where addr LIKE in ('john@google.com', 'jim@google.com')

我该怎么做?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2011-04-06 02:03:11

将值放入表中,并使用join而不是in子句:

代码语言:javascript
复制
SELECT * FROM emailaddresses as ea
INNER JOIN addresses as a
ON ea.address like '%' + a.address + '%'
票数 12
EN

Stack Overflow用户

发布于 2011-04-06 02:02:06

您可以使用LOWER function

代码语言:javascript
复制
SELECT * FROM emailaddresses where LOWER(addr) in ('john@google.com', 'jim@google.com')

它会将所有addr转换为小写,这样您就可以将结果与您想要的结果进行比较。

票数 2
EN

Stack Overflow用户

发布于 2011-04-06 02:13:19

请注意,LIKE将区分大小写还是不区分大小写,这取决于对表达式有效的排序规则,但在本例中,您没有指定通配符,因此使用LIKE的意义不大。

默认的SQL Server安装不区分大小写。

如果您想要不区分大小写的比较,因为您有一个区分大小写的数据库,you can cast。我相信这是合适的语法(尽管我从来没有在表达式的一侧使用过它作为IN列表)。

代码语言:javascript
复制
SELECT *
FROM emailaddresses
WHERE addr COLLATE SQL_Latin1_General_CP1_CI_AS 
IN (
    'john@google.com' COLLATE SQL_Latin1_General_CP1_CI_AS
    ,'jim@google.com' COLLATE SQL_Latin1_General_CP1_CI_AS
)

addr LIKE '%@google.com"这样的东西才是LIKE的真实案例

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5556299

复制
相关文章

相似问题

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