首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将以逗号分隔的SQL数据转换为SQL "in“指令

将以逗号分隔的SQL数据转换为SQL "in“指令
EN

Stack Overflow用户
提问于 2014-12-15 15:05:06
回答 4查看 100关注 0票数 4

第一条声明:

代码语言:javascript
运行
复制
Select GroupMember
FROM Group 

结果:洛杉矶,圣地亚哥(它是一个字符串)

第二条声明:

代码语言:javascript
运行
复制
 SELECT *
 FROM Store_Information 
 WHERE Store_Name IN ('Los Angeles', 'San Diego');

如何将洛杉矶,圣地亚哥(一个数据)转换为IN (“洛杉矶”,“圣地亚哥”)?

EN

回答 4

Stack Overflow用户

发布于 2014-12-15 15:07:44

使用内部查询

代码语言:javascript
运行
复制
SELECT * FROM Store_Information
WHERE Store_Name IN (Select GroupMember FROM Group)
票数 3
EN

Stack Overflow用户

发布于 2014-12-15 15:31:30

您可以将查询编写为

代码语言:javascript
运行
复制
SELECT * 
FROM 
Store_Information WHERE Store_Name IN (
SELECT Split.a.value('.', 'VARCHAR(100)') AS String   
       FROM  (SELECT  CAST ('<M>' + REPLACE(groupname, ',', '</M><M>') + '</M>' 
                             AS XML) AS groupname       
               FROM  Group) 
       AS A 
CROSS APPLY groupname.nodes ('/M') AS Split(a))
票数 1
EN

Stack Overflow用户

发布于 2014-12-15 15:16:03

虽然您可以使用子查询来实现,但更好的方法是使用连接:

代码语言:javascript
运行
复制
SELECT s.*
FROM Store_Information s
JOIN Group g ON g.GroupMember = s.Store_Name
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27478914

复制
相关文章

相似问题

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