zoukankan      html  css  js  c++  java
  • SQL Server字符串聚合拼接办法

    数据范例如下:

    要得到的结果目标,获取type相同的所有names拼接在一起的字符串:

    SqlServer并没有一个直接拼接字符串的函数,下面所提到的方法,只是日常的开发中自己个人用到的一些思路,仅供参考!

    declare @tempTable table([Type] int,[Name] nvarchar(100))

    创建表变量,字段为你需要返回的各列的值

    insert @tempTable
    select [type],MAX([name]) name
    from test
    group by [type]

    插入初始的聚合数据

    updateTag:
    update @tempTable
    set [name] += (','+ a.[name])
    from test a,@tempTable b
    where a.[Type] = B.[Type] 
    and CHARINDEX(a.[name],b.[name]) = 0
    if @@ROWCOUNT > 0
    begin
        GOTO updateTag
    end
    
    select * from @tempTable

    循环插入其他满足条件的聚合数据,这种方案适合包含聚合条件比较复杂的情况,比如需要查询聚合多列拼接字符串结果,其中还涉及到一些列的复杂运算,但是劣势也很明显,如果分组聚合的项比较多时,会比较耗时,因为有一个循环效率不是很高的insert,但是对于几十或者几百次的循环来说还是没太大的问题的。

    其实网上搜了一圈还是有不错的方法的,比如STUFF函数,我们可以这么写得到上面的结果:

    SELECT [TYPE], STUFF(
    ( SELECT ','+ [Name] 
    FROM test b 
    WHERE b.Type = a.Type 
    FOR XML PATH('')),1 ,1, '') [Names]
    from Test a
    group by [TYPE]

    至于这个函数用法,这里就不多解释了,希望以上两种方案对您有一点帮助或者启示!

  • 相关阅读:
    oracle11g2下载安装笔记
    eclipse的下载安装配置
    实现图片的缩放 添加鼠标滑轮事件
    MySQL5.7.21非图形化下载、安装、连接问题记录
    python学习登录接口
    python学习计算器
    python学习简单购物商城的实现
    python学习三级菜单
    ios学习之UISwipeGestureRecognizer手势识别
    ”isEqual“ ”isEqalToString“ 和“==”三者区别
  • 原文地址:https://www.cnblogs.com/stealth7/p/6891211.html
Copyright © 2011-2022 走看看