参考这个:
分拆列值原著:邹建
改编:爱新觉罗.毓华  2007-12-16  广东深圳有表tb, 如下:
id          value
----------- -----------
1           aa,bb
2           aaa,bbb,ccc
欲按id,分拆value列, 分拆后结果如下:
id          value
----------- --------
1           aa
1           bb
2           aaa
2           bbb
2           ccc1. 旧的解决方法
SELECT TOP 8000 id = IDENTITY(int, 1, 1) INTO # FROM syscolumns a, syscolumns b SELECT A.id, SUBSTRING(A.[values], B.id, CHARINDEX(',', A.[values] + ',', B.id) - B.id)
FROM tb A, # B
WHERE SUBSTRING(',' + A.[values], B.id, 1) = ','DROP TABLE #2. 新的解决方法 create table tb(id int,value varchar(30))
insert into tb values(1,'aa,bb')
insert into tb values(2,'aaa,bbb,ccc')
go
SELECT A.id, B.value
FROM(
    SELECT id, [value] = CONVERT(xml,'<root><v>' + REPLACE([value], ',', '</v><v>') + '</v></root>') FROM tb
)A
OUTER APPLY(
    SELECT value = N.v.value('.', 'varchar(100)') FROM A.[value].nodes('/root/v') N(v)
)BDROP TABLE tb/*
id          value
----------- ------------------------------
1           aa
1           bb
2           aaa
2           bbb
2           ccc(5 行受影响)
*/

解决方案 »

  1.   

    就是把表1connet中的字母由横排列,转化为竖排列
      

  2.   

    你这样是采用的临时表,如果直接把表1的拆分结果放在已经建好的表2里,怎么弄,求语言。  如下 表1中:
      id          value
     ----------- -----------
      1           01,02
      2           01,02,03
      
     按id,分拆value列, 分拆后结果如下表2:
      id          value
      ----------- --------
      1           01
      1           02
      2           01
      2           02
      2           03
      

  3.   


    create table os(id int,value varchar(50))
    insert into os select 1,'01,02'
    insert into os select 2,'01,02,03'
    declare @sql varchar(8000)
    set @sql=''
    select @sql=@sql+replace(','+value,',','''[value] union select '+ltrim(id)+'[id],''') from os
    set @sql=stuff(@sql,1,14,'')+''''
    exec(@sql)