zoukankan      html  css  js  c++  java
  • 分组合并的使用

    问题:一个表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

            思路二:自定义函数

            重在思考问题的方向

  • 相关阅读:
    解释之前遗留的方法覆盖问题
    多态在开发中的作用
    多态的基础语法
    Go 统计汉子字符
    Go map
    Go make和new的区别
    Go 指针
    Go 切片
    Go数组
    Go中交换两个值类型
  • 原文地址:https://www.cnblogs.com/syf/p/2452656.html
Copyright © 2011-2022 走看看