SqlServer自定义聚合函数

sqlserver2017版本包括以上的可以使用string_agg(字段,’,’)函数

sqlserver查询版本:
select @@version

Sql Server自定义聚合函数详细bai步骤

开始->
在这里插入图片描述

输出->
在这里插入图片描述

首先用baiVS2008/VS2005建立一个SQL Server项目,右键解决方案添加新项
在这里插入图片描述
点击“确定”bai按钮后,SQL Server项目会要求连接一个数据库,我们可以选择一个数据库

在这里插入图片描述
然后在工程中加入一个聚合类(joinstr.cs),如图
在这里插入图片描述
joinstr.cs中的最终代码如下:

using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
using System.Text;
                              
                              
[Serializable]
[SqlUserDefinedAggregate(
    Format.UserDefined, //use custom serialization to serialize the intermediate result
    IsInvariantToNulls = true, //optimizer property
    IsInvariantToDuplicates = false, //optimizer property
    IsInvariantToOrder = false, //optimizer property    
    MaxByteSize = 8000), //maximum size in bytes of persisted value
]
                              
                              
public struct JoinStr:IBinarySerialize
{
    private StringBuilder sbIntermediate;
    public void Init()
    {
       sbIntermediate = new StringBuilder();
    }
                              
    public void Accumulate(SqlString Value)
    {
                              
        if (Value == null || Value.ToString().ToLower().Equals("null"))
        {
            return;
        }
        else
        {
            sbIntermediate.Append(Value);
        }
    }
                              
    public void Merge(JionStr Group)
    {
        sbIntermediate.Append(Group.sbIntermediate);
    }
                              
    public SqlString Terminate()
    {
                                     
        return new SqlString(sbIntermediate.ToString());
    }
                              
    // This is a place-holder member field
                              
                              
    #region IBinarySerialize Members
                              
    public void Read(System.IO.BinaryReader r)
    {
        sbIntermediate = new StringBuilder(r.ReadString());
    }
                              
    public void Write(System.IO.BinaryWriter w)
    {
        w.Write(this.sbIntermediate.ToString());    
    }
    #endregion
}

在编写完上述代码后,可以使用Visual Studio来部署(右向工程,在弹出菜单上选“部署”即可)。

在执行上面的SQL语句之前,需要将SQL Server2005的clr功能打开

在这里插入图片描述
也可以用SQL打开clr功能:

EXEC sp_configure 'clr enabled', 1
RECONFIGURE WITH OVERRIDE
GO

现在可以使用joinstr来聚合字符串了。

select [t_code_role].[role_mc] as '角色',dbo.JoinStr([t_code_right].[right_mc]+',') as '权限' from [t_data_roleright],[t_code_right],[t_code_role] where [t_data_roleright].[role_bm]=[t_code_role].[role_bm] and [t_data_roleright].[right_bm]=[t_code_right].[right_bm] group by [t_code_role].[role_mc]

转载地址:感谢 dyt0801

方案二:https://www.bbsmax.com/A/gVdnmXb15W/

方案三:http://blog.leanote.com/post/colin_xia@yeah.net/sql-server-%E6%B7%BB%E5%8A%A0%E5%AD%97%E7%AC%A6%E4%B8%B2%E8%81%9A%E5%90%88%E5%87%BD%E6%95%B0

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值