我希望将下面的字符串(出现在一列中)从末尾用空格分隔开。对于下面的3行,我希望得到以下输出
输出:
Country STATE STREET UNIT
AU NSW 2 12
AU NSW 51
AU NSW 12输入:
12诺埃拉广场2号圣玛丽新南威尔士2760 AU
南库吉马拉巴路51号新南威尔士2034非盟
利斯特街12号温斯顿山新南威尔士州2153 AU
发布于 2017-10-15 09:31:12
当然,这种条件解析不可靠:
t=# with v(a) as( values('12 2 NOELA PLACE ST MARYS NSW 2760 AU')
,('51 MALABAR ROAD SOUTH COOGEE NSW 2034 AU')
,('12 LISTER STREET WINSTON HILLS NSW 2153 AU')
)
select reverse(split_part(reverse(a),' ',1)), reverse(split_part(reverse(a),' ',3)), case when split_part(a,' ',2) ~ '\d' then split_part(a,' ',2) end st, split_part(a,' ',1) un from v;
reverse | reverse | st | un
---------+---------+----+----
AU | NSW | 2 | 12
AU | NSW | | 51
AU | NSW | | 12
(3 rows)https://stackoverflow.com/questions/46752914
复制相似问题