暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Clickhouse 字符串拆分&一行转多行

老柴杂货铺 2021-12-09
7151

想把 '123_456_789_987_654_321' 通过'_' 下划线进行拆分成 👇的结果

123

456

789

987

654

321


一、字符串拆分函数  splitByChar(分隔符,s)

将字符串以'separator'拆分成多个子串。'separator'必须为仅包含一个字符的字符串常量。

返回拆分后的子串的数组。如果分隔符出现在字符串的开头或结尾,或者如果有多个连续的分隔符,则将在对应位置填充空的子串。

select     splitByChar('_', '123_456_789_987_654_321') AS src
复制

结果输出👇:

我们可以看到该字符串拆分后,组成来一个数组,后面的'_' 两下划线,就是指在多个连续的分隔符的情况下,则在对应的位置填充空的子串。


二、 arrayJoin函数 

'arrayJoin'函数获取每一行并将他们展开到多行(unfold)。

此函数将数组作为参数,并将该行在结果集中复制数组元素个数。

除了应用此函数的列中的值之外,简单地复制列中的所有值;它被替换为相应的数组值。

SELECT arrayJoin(['123','456','789','987','654','321'] AS src) AS dst,  src;
复制

结果👇:

有了这两个函数之后,应该对于字符串拆分有点头绪了吧,就两个函数搞定,就是那么简单粗暴。

select  toInt32(arrayJoin(splitByChar('_', '123_456_789_987_654_321') AS src)) as number;
复制


文中内容在clickhouse 20.8.3.18中测试通过

文章转载自老柴杂货铺,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论