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 -->表示匹配到的第二个字段
这样就能达到这个效果