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

            思路二:自定义函数

            重在思考问题的方向

  • 相关阅读:
    数据库管理 trove openstack
    Vmware 给虚拟机传脚本并执行
    Vmware 控制脚本
    python 脚本之 IP地址探测
    python 模块之-ffmpeg 中文参数对照表
    VMware ezmomi工具使用
    VS编译器从DLL导出模板类
    Qt5+VS2012编程
    Visual Studio 2012优化
    计算几何
  • 原文地址:https://www.cnblogs.com/syf/p/2452656.html
Copyright © 2011-2022 走看看