clickhouse使用extract提取分号之前,之后,中间的内容

Area:'安徽;宣城;宣州',要提取分号之前,两个分号之前,最后一个分号之后的内容作为省市区

这是最后得到的正确的结果,感谢chatgpt

刚开始本来想使用splitByString

复制代码
-- 宣城
select splitByString(';','安徽;宣城;宣州')[2];

可以直接指定分隔符拆分成字符串数组,但是我的这个表的这个字段设计是Nullable类型的,没法使用这个函数使用这个函数会报错,就算使用where过滤也是不行的

select splitByString(';',Area)[2] from (select Area from table where Area is not null and Area != '');

复制代码
还有positionUTF8,substringUTF8也尝试过了,也不能对Nullable类型的字段使用
select  Area,positionUTF8(Area,';',1),substringUTF8(Area,1,length(Area)-positionUTF8(Area,';',1))
from table where BillNo = '76AJNX1ZE334FD2';
最后只能用extract函数了,通过正则表达式进行提取。

-- 1,获取省
SELECT
    extract('安徽;宣城;宣州', '([^;]+)') AS extracted_text,extractAll('安徽;宣城;宣州', '([^;]+)')[3] AS extracted_text2;

SELECT
    Area,extract(Area, '([^;]+)') from  table where BillNo = '76AJNX1ZE314FD1';
-- 最简单的方式是使用extractAll('安徽;宣城;宣州', '([^;]+)')根据分号拆分成数组,但是由于clickhouse限制无法对Nullable类型的字符串使用这个函数,
-- 等同于splitByString函数,select splitByString(';','安徽;宣城;宣州')[2];
-- SELECT
--     extractAll(Area, '([^;]+)')[3] AS extracted_text2 from table where BillNo = '76AJNX1ZE334FD2';
-- 2,获取市
SELECT
    extract('安徽;宣城;宣州', ';([^;]+);') AS extracted_text;

-- 3,获取区
SELECT extract('安徽;宣城;宣州', ';([^;]+)$') AS extracted_text;
相关推荐
麦兜和小可的舅舅5 天前
ClickHouse 一次Schema修改造成的Merge阻塞问题的分析和解决过程
clickhouse
bigdata-rookie8 天前
StarRocks(2.5.1)vs Clickhouse(21.7.3.14)集群 SSB 性能测试
clickhouse
CTO Plus技术服务中8 天前
ClickHouse原理解析与应用实践教程
clickhouse
zhangyifang_00910 天前
ClickHouse查询报错:Code: 62. DB::Exception: Max query size exceeded:
数据库·clickhouse
HideInTime10 天前
Clickhouse进阶分组复合排序查询
clickhouse
memgLIFE11 天前
clickhouse
clickhouse
Arbori_2621512 天前
clickhouse 实现mysql GROUP_CONCAT() 函数
数据库·mysql·clickhouse
斯普信专业组13 天前
Nomad组件部署clickhouse-job
clickhouse·nomad
麦兜和小可的舅舅13 天前
ClickHouse Drop Table On Cluster 故障分析和原理解析
clickhouse·kafka
重生之绝世牛码15 天前
Linux软件安装 —— ClickHouse单节点安装(rpm安装、tar安装两种安装方式)
大数据·linux·运维·数据库·clickhouse·软件安装·clickhouse单节点