首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >红移中逗号分隔字段中的匹配值

红移中逗号分隔字段中的匹配值
EN

Stack Overflow用户
提问于 2020-12-21 23:17:52
回答 1查看 196关注 0票数 0

Redshift中有两个表,如下所示:

代码语言:javascript
复制
T1:

QID   EID
Q1    a.1,a.2
Q2    a.5,a.4,a.8
Q3    a.7
Q4    a.3,a.5

代码语言:javascript
复制
T2:

EIDs
a.1
a.2
a.4
a.7

我只想从T1中选择包含T2.EIDs中任何可用值的记录。因此,如果T2.EIDs中的任何值在逗号分隔的字段T1.EID中可用,那么我希望从T1中选择该记录。对于给定的示例,下面是我想要的结果集:

代码语言:javascript
复制
QID   EID
Q1    a.1,a.2
Q2    a.5,a.4,a.8
Q3    a.7

我知道LIKESIMILAR TO条款会在这里起作用,但我似乎想不出什么东西能让它发挥作用。

最后的查询可能如下所示:

代码语言:javascript
复制
SELECT T1.*
FROM T1 JOIN T2 ON <cannot think of a proper join condition>

任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-21 23:20:10

这是一个糟糕的数据模型。CSV列表中的每个值都应该存储在不同的行中,而不是串连在字符串中。那么查询就很容易编写,效率也很高。

对于当前的设计,可以使用以下字符串函数:

代码语言:javascript
复制
select t1.*
fom t1
where exists (select 1 from t2 where ',' || t1.eid || ',' like '%,' || t2.eid || ',%')
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65401256

复制
相关文章

相似问题

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