分组合并的使用

 

问题:一个表test,有2列:firstname varchar(50),domain varchar(50)。

test表有如下数据行:

firstname      domain

----------------------

tony              group1

tony              group2

tony              group3

john              group4

 

提问:求一条sql,查询结果可以按如下格式显示:

firstname             domain

---------------------------

tony                  group1,group2,group3

john                  group4

 

 

解决方法1

select [name],(select [group] from test where name=x.name for xml path('')) from test x group by  [name]

解决方法2

通过函数的方式

 

参考例子

create function  Sum_ByGroup(@DepartmentName varchar(50))   
returns varchar(8000)   
as   
begin   
    
declare @ret varchar(8000)   
    
set   @ret  =  ''   
    
select  @ret  =  @ret+','+EmpoyeeName from Employees where DepartmentName = @DepartmentName   
    
set   @ret   =   stuff(@ret,1,1,'')   
    
return   @ret     
end   
go

select DepartmentName,dbo.Sum_ByGroup(DepartmentName) as EmployeesList from Employees
group by DepartmentName
go

 

总结:对于group by的问题

        思路一:for xml path

        思路二:自定义函数

        重在思考问题的方向

 

转载于:https://www.cnblogs.com/syf/archive/2012/04/16/2452656.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值