首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何对字符串进行多个拆分(在查询中)

如何对字符串进行多个拆分(在查询中)
EN

Stack Overflow用户
提问于 2016-08-21 06:13:52
回答 1查看 223关注 0票数 3

我将字符串作为param (通过massivejs)传递到我的查询中。字符串被格式化为:param = 'red, blue, green'。param本身不具有固定的长度(“,”是分隔符),因为它是通过用户发送的内容填充的(但最多只有10个元素)。

如何将字符串分解为查询中的单个字符串?

我想做的事:

代码语言:javascript
复制
SELECT * FROM table
WHERE name IN (param);

我知道这是可行的,但非常粗糙:

代码语言:javascript
复制
SELECT * FROM table
WHERE name IN (split_part(param, ',', 1), split_part(param, ',', 2) .......)) -- keep going. 

本质上我想要(“红色”,“蓝色”,“绿色”)在括号内。有什么更好的方法来完成这件事?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-21 06:18:52

可以使用string_to_array函数将字符串拆分为数组,然后使用any函数检查元素是否包含在其中:

代码语言:javascript
复制
SELECT * 
FROM   mytable
WHERE  name = ANY(STRING_TO_ARRAY(param, ','));
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39061358

复制
相关文章

相似问题

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