参考这个:
分拆列值原著:邹建
改编:爱新觉罗.毓华 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 行受影响)
*/
分拆列值原著:邹建
改编:爱新觉罗.毓华 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 行受影响)
*/
解决方案 »
- 正在控制台上的SQL Server数据库怎么复制一份
- 数据倒入,字段后面的回车符怎么去掉
- sql server 计算列
- server 2008 + sql 2008 报表
- sql 按列A分组后只保留B列最大行的数据
- 关于备份恢复的疑问(backup [restore] database...)
- 中文排序的问题,求助!
- 请教一个问题 单位的数据程序只能导出excel文件格式 数据每天更新 我要将这些数据导入到sqlserver 里做成内部网站 数据每天都要更新 有几十万条
- 请问,我做了一个采购管理的SQL数据库,如何做一个前台让其他人也能添加或删除数据?
- 请教sql的问题
- 服务器换ip,sqlserver打开很慢?
- 一个算法问题,求好方法
id value
----------- -----------
1 01,02
2 01,02,03
按id,分拆value列, 分拆后结果如下表2:
id value
----------- --------
1 01
1 02
2 01
2 02
2 03
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)