将逗号分隔的字段拆解成记录

1, '1,2' , 'a,b'
2 , '1,3' , 'a,c,d'

拆成

1,1,a

1,1,b

1,2,a

1,2,b

2,1,a

2,1,c

2,1,d

2,3,a

2,3,c

2,3,d

IF OBJECT_ID('tb') IS NOT NULL

DROP TABLE tb

GO

CREATE TABLE tb( id int, code varchar(10),code2 varchar(10))

go

insert tb SELECT 



1, '1,2' , 'a,b' UNION ALL SELECT 

2 , '1,3' , 'a,c,d' 

go

select a.id,code,code2=substring(a.code2,b.number,charindex(',',a.code2+',',b.number)-b.number) 

from (

Select

a.id,code=substring(a.code,b.number,charindex(',',a.code+',',b.number)-b.number) ,code2

from 

Tb a join master..spt_values b 

ON B.type='p' AND B.number BETWEEN 1 AND LEN(A.code)

where

substring(','+a.code,b.number,1)=',') a join master..spt_values b 

ON B.type='p' AND B.number BETWEEN 1 AND LEN(A.code2)

where

substring(','+a.code2,b.number,1)=','



go

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值