a表
a列 b列
1 a
1 b
1 c
2 a
2 b
能否不用存储过程 直接sql 得到
1 a,b,c
2 a,b,c
这样的结果
可以的,用交叉方法
select a列,
max(case when b列='a' then 'a' else '' end) 列1,
max(case when b列='b' then 'b' else '' end) 列2,
max(case when b列='c' then 'c' else '' end) 列3
into temp_1219--插入临时表
from a表
group by a列
这个是静态的行列转换,
如果是动态的行列装换,也就是说你不知道表中a列的行数有很多,需要写过程对sql语句进行拼接
然后根据你的需要再对字段进行合并
select a列,列1+','+列2+','+列3 b列
into temp_1219_result--插入结果表
from temp_1219
/*--优化
update temp_1219
set 列2=','+列2
where len(列2)>0
update temp_1219
set 列3=','+列3
where len(列3)>0
select a列,列1+列2+列3 b列
into temp_1219_result2--插入结果表
from temp_1219
*/
案例2:
测试数据
编号 物料类别 产品编号
1 铅笔 0001
2 铅笔 0002
3 铅笔 0001
4 钢笔 0004
5 钢笔 0005
6 钢笔 0004
7 圆珠笔 0007
8 圆珠笔 0008
9 圆珠笔 0007
等等
要求实现以下效果:
编号 物料类别 产品编号
1 铅笔 0001,0002
2 钢笔 0004,0005
3 圆珠笔 0007,0008
**我的目的是如果不重复则合并产品编号,如果重复则舍弃**
create table T(编号 int, 物料类别 nvarchar(10), 产品编号 char(5))
insert T select 1, '铅笔', '0001'
union all select 2, '铅笔', '0002'
union all select 3, '铅笔', '0001'
union all select 4, '钢笔', '0004'
union all select 5, '钢笔', '0005'
union all select 6, '钢笔', '0004'
union all select 7, '圆珠笔', '0007'
union all select 8, '圆珠笔', '0008'
union all select 9, '圆珠笔', '0007'
create function fun(@物料类别 nvarchar(10))
returns nvarchar(200)
as
begin
declare @re nvarchar(200)
set @re=''
select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号
select @re=left(@re, len(@re)-1)
return @re
end
select distinct 物料类别, dbo.fun(物料类别) from T
--result
物料类别
---------- -------------------------------
钢笔 0004 ,0005
铅笔 0001 ,0002
圆珠笔 0007 ,0008
(3 row(s) affected)
后記:
核心語句中最后面的group by XXX 可舍棄重復。
select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号
又一篇笔记,以备后用!!
需求:
有表tb,表有两个字段,分别为:id,value。
表中存有数据如下:id value
1 a
1 a1
1 a2
2 b
2 b1
3 c1
3 c2
需要通过查询实现:1 a,a1,a2
2 b,b1
3 c1,c2
实现方法:
1、sql2000 使用合并函数:
create function f_tb(@id int)
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str = ''
select @str = @str + ',' + cast(value as varchar) from tb where id = @id
set @str = right(@str , len(@str) - 1)
return(@str)
End
go
--调用自定义函数得到结果:
select distinct id ,dbo.f_tb(id) as value from t
2、sql2005 处理方式如下:
SELECT * FROM(SELECT DISTINCT id FROM tb)A OUTER APPLY(
SELECT [values]= STUFF(REPLACE(REPLACE(
(
SELECT value FROM tb N
WHERE id = A.id
FOR XML AUTO
), '<N value="', ','), '"/>', ''), 1, 1, '')
)N