regexp_substr()函数的用法:

regexp_substr()函数的用法:


在SQL中尝试使用正则,可以试下regexp_substr()来进行分割

1.首先创建一个实验视图:

SQL>

create or replace view test_ip as select '192.168.1.1' as ip from dual
 union all
select '192.168.1.2' as  ip from dual 
union all 
select '192.168.1.3' as  ip from dual
union all
select '192.168.1.4' as  ip from dual;

2.查看下视图的整体结构
SQL> select * from test_ip;

IP
-----------
192.168.1.1
192.168.1.2
192.168.1.3
192.168.1.4

3.实例
(1)现在有一个需求,需要将这些ip以“.”为分隔符,分段显示ip
最终效果如下:

IP1                    IP2                    IP3                    IP4
---------------------- ---------------------- ---------------------- -----
192                    168                    1                      1
192                    168                    1                      2
192                    168                    1                      3
192                    168                    1                      4

执行的SQL如下:

select regexp_substr(a.ip, ‘[^.]+’, 1, 1) ip1,
regexp_substr(a.ip, ‘[^.]+’, 1, 2) ip2,
regexp_substr(a.ip, ‘[^.]+’, 1, 3) ip3,
regexp_substr(a.ip, ‘[^.]+’, 1, 4) ip4 from test_ip a;

分析:

regexp_substr()括号中的
[^.]   -->代表除了“.”以外的全部字段
+      -->表示匹配1次以上
1      -->表示从第一个“.”开始
2      -->表示匹配到的第二个字段

这样就能达到这个效果

你可能感兴趣的:(数据库,oracle,数据库,database)