博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle一列中的数据有多个手机号码用逗号隔开,我如何分别取出来?
阅读量:6121 次
发布时间:2019-06-21

本文共 918 字,大约阅读时间需要 3 分钟。

ID      NUMBER 1       137xxxx,138xxxx 取出来成 ID    NUMBER 1     137xxxx 1     138xxxx
create 
table 
test
(id 
int
,
phone varchar2(200));
insert 
into 
test 
values 
(1,
'13811111111,13311111111,13900000000'
);
insert into test values (2,'15811111111,15911111111,18800000000'); 第一种方式
select 
id,c 
from
(
with 
as 
(
select 
id,phone c 
from 
test)
select 
id,substr(t.ca,instr(t.ca, 
','
, 1, c.lv) + 1,instr(t.ca, 
','
, 1, c.lv + 1) - (instr(t.ca, 
','
, 1, c.lv) + 1)) 
AS 
c
from 
(
select 
id,
',' 
|| c || 
',' 
AS 
ca,length(c || 
','
) - nvl(length(
REPLACE
(c, 
','
)),0) 
AS 
cnt 
FROM 
t) t,
(
select 
LEVEL 
lv 
from 
dual 
CONNECT 
BY 
LEVEL 
<= 100) c 
where 
c.lv <= t.cnt) 
order 
by 
id
 
第二种方式  由
SELECT
id,
       
regexp_substr(phone,
'[^,]+'
, 1,
LEVEL
) mobile
FROM  
test
CONNECT
BY
PRIOR
id = id
    
AND   
PRIOR
dbms_random.VALUE
IS
NOT
NULL
    
AND   
LEVEL
<= length(phone) - length(
REPLACE
(phone,
','
)) + 1
 

转载于:https://www.cnblogs.com/myjoan/p/4139348.html

你可能感兴趣的文章
解读自定义UICollectionViewLayout--感动了我自己
查看>>
SqlServer作业指定目标服务器
查看>>
UnrealEngine4.5 BluePrint初始化中遇到编译警告的解决办法
查看>>
User implements HttpSessionBindingListener
查看>>
抽象工厂方法
查看>>
ubuntu apt-get 安装 lnmp
查看>>
焊盘 往同一个方向增加 固定的长度方法 总结
查看>>
eclipse的maven、Scala环境搭建
查看>>
架构师之路(一)- 什么是软件架构
查看>>
jquery的冒泡和默认行为
查看>>
USACO 土地购买
查看>>
【原创】远景能源面试--一面
查看>>
B1010.一元多项式求导(25)
查看>>
10、程序员和编译器之间的关系
查看>>
前端学习之正则表达式
查看>>
配置 RAILS FOR JRUBY1.7.4
查看>>
AndroidStudio中导入SlidingMenu报错解决方案
查看>>
修改GRUB2背景图片
查看>>
Ajax异步
查看>>
好记性不如烂笔杆-android学习笔记<十六> switcher和gallery
查看>>