Script: PostgreSQL 实现字符串拆分 split (二)

栏目: 数据库 · 发布时间: 6年前

内容简介:几年前写过一篇在oracle 使用oracle函数实现的类似java 语言中的split 拆分功能,这篇改用PostgreSQL实现类型的功能。在PG提供了两个函数用于拆份字符串:

几年前写过一篇在oracle 使用oracle函数实现的类似 java 语言中的split 拆分功能,这篇改用PostgreSQL实现类型的功能。

Script:oracle拆分逗号分隔字符串 实现split

在PG提供了两个函数用于拆份字符串:

regexp_split_to_array:它根据正则表达式拆分字符串并将其部分返回到数组中。

regexp_split_to_table:它根据正则表达式将字符串拆分为多个部分,并将其部分返回到表的行中。

下面还是以”,”逗号分隔拆分:

— REGEXP_SPLIT_TO_ARRAY

postgres=# select 'first field, second field , third field' as str
postgres-# ;
                   str
-----------------------------------------
 first field, second field , third field
(1 row)

postgres=# select regexp_split_to_array('first field, second field , third field',E'\\,') as ar_str;
                     ar_str
-------------------------------------------------
 {"first field"," second field "," third field"}
(1 row)

postgres=# select  ar_str[1] AS str1, ar_str[2] AS str2,ar_str[3] AS str3 from (
postgres(# select regexp_split_to_array('first field, second field , third field',E'\\,') as  ar_str
postgres(# ) v;
    str1     |      str2      |     str3
-------------+----------------+--------------
 first field |  second field  |  third field
(1 row)

postgres=# select ar_str[_idx] from (
postgres(#   select  generate_subscripts(ar_str,1) as _idx, ar_str from (
postgres(#   select regexp_split_to_array('first field, second field , third field',E'\\,') as  ar_str
postgres(#   ) v
postgres(# ) v1;
     ar_str
----------------
 first field
  second field
  third field


postgres=# SELECT (regexp_split_to_array('www.ANBOB.com', E'\\.'))[2];
 regexp_split_to_array
-----------------------
 ANBOB
(1 row)

-- 以空格拆分
postgres=# SELECT regexp_split_to_array('hello PG', E'\\s+')
postgres-# ;
 regexp_split_to_array
-----------------------
 {hello,PG}
(1 row)

— regexp_split_to_table

postgres=# select regexp_split_to_table('first field, second field , third field',',') as tab_str;
    tab_str
----------------
 first field
  second field
  third field
(3 rows)

postgres=# SELECT tab_num::INTEGER

postgres-# FROM regexp_split_to_table(‘1,3,2,4,7,5,9,10’, ‘,’) AS tab_num

postgres-# ORDER BY 1;

tab_num

———

1

2

3

4

5

7

9

10

(8 rows)

WOW! 是否很方便?

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

鲜活的数据

鲜活的数据

[美] Nathan Yau / 向怡宁 / 人民邮电出版社 / 2012-10-1 / 69.00元

在生活中,数据几乎无处不在,任我们取用。然而,同样的数据给人的感觉可能会千差万别:或冰冷枯燥,让人望而生畏、百思不解其意;或生动有趣,让人一目了然、豁然开朗。为了达到后一种效果,我们需要采用一种特别的方式来展示数据,来解释、分析和应用它。这就是数据可视化技术。Nath an Yau是这一创新领域的先锋。在本书中,他根据数据可视化的工作流程,先后介绍了如何获取数据,将数据格式化,用可视化工具(如R)......一起来看看 《鲜活的数据》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码