微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

查询中的 Athena/Presto 拆分字符串

如何解决查询中的 Athena/Presto 拆分字符串

是否可以对 IN 查询使用逗号分隔的字符串?

我想使用字符串 a,b,c

执行以下查询

select * from tablename where colname in ('a','b','c')

示例 - select * from tablename where colname in (split_string('a,c'))

解决方法

您可以使用 split(string,delimiter) 拆分字符串和布尔函数 contains(array,element) 来检查数组是否包含值:

 select * from tablename where contains(split('a,b,c',','),colname)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。