请问:怎样把某个表按照某些列分组后,剩下的一个字符列相加,并且把这些列显示出来。谢谢帮助!

booksfount 2005-03-01 11:46:21
以下是我写在存储过程中的一段话:但是报语法错误。
select a.c_prodTypeName,a.c_ProdName ,a.c_AnalysisItem ,a.d_Date ,
(select @smor = @smor+' '+b.mor from #disgrid b --就是这行出错的。
where a.c_prodTypeName = b.c_prodTypeName
and a.c_ProdName = b.c_ProdName
and a.c_AnalysisItem = b.c_AnalysisItem
and a.d_Date = b.d_Date and b.mor<>'' ) as mor
from #disgrid a
group by a.c_prodTypeName,a.c_ProdName ,a.c_AnalysisItem ,a.d_Date

错误如下:
第 89 行: '=' 附近有语法错误。

mor 字符型的
@smor定义的是varchar(8000)
单独执行这句话,是没有错误的
select @smor = @smor+' '+b.mor from #disgrid b

如果把上面的@smor = @smor+' '+b.mor修改为任何一个max(b.mor) 就没有错误了,但是就不是我想要得数据了。

我想达到的效果是这样的
假如有这样一个表
1 a
1 b
1 c
2 d
2 e
2 f
结果
1 a b c
2 d e f
字符串间用空格分割
就是按照id分组了。

谢谢帮助。我想在存储过程中实现此功能,不想在开发语言中实现。不知可否?谢谢!
...全文
76 点赞 收藏 3
写回复
3 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
booksfount 2005-03-01
谢谢!我试验一下!
回复
zheninchangjiang 2005-03-01
赋值和记录集
建议做个函数(标例)
create function f_test(@col as varchar(2))
returns varchar(100)
as
begin
declare @s varchar(100)
set @s=''
select @s=@s+col2+',' from [table] where col1=@col
return(left(@s,len(@s)-1))
end
go

seelect col1,dbo.f_test(col1) from [table] group by col1
回复
子陌红尘 2005-03-01
参考这个函数:
--------------------------------------------------------
create function f_str(@c_prodTypeName varchar(10))
returns varchar(8000)
as
begin
declare @r varchar(8000)
set @r=''
select @r=@r+' '+rtrim(mor)
from table where c_prodTypeName=@c_prodTypeName
return(stuff(@r,1,1,''))
end
回复
发帖
应用实例
创建于2007-09-28

2.7w+

社区成员

MS-SQL Server 应用实例
申请成为版主
帖子事件
创建了帖子
2005-03-01 11:46
社区公告
暂无公告