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

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分组了。

谢谢帮助。我想在存储过程中实现此功能,不想在开发语言中实现。不知可否?谢谢!
...全文
103 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
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

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧