1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
如下表:AggregationTableId Name
1 赵
2 钱
1 孙
1 李
2 周
如果想得到下图的聚合结果
Id Name
1 赵孙李
2 钱周
利用 SUM 、 AVG 、 COUNT 、 COUNT (*)、 MAX 和 MIN 是无法做到的。因为这些都是对数值的聚合。不过我们可以通过自定义函数的方式来解决这个问题。
1.首先建立测试表,并插入测试数据:
复制代码代码如下:
create table AggregationTable(Id int , [ Name ] varchar (10))
go
insert into AggregationTable
select 1, '赵' union all
select 2, '钱' union all
select 1, '孙' union all
select 1, '李' union all
select 2, '周'
go
2.创建自定义字符串聚合函数
复制代码代码如下:
Create FUNCTION AggregateString
(
@Id int
)
RETURNS varchar (1024)
AS
BEGIN
declare @Str varchar (1024)
set @Str = ''
select @Str = @Str + [ Name ] from AggregationTable
where [Id] = @Id
return @Str
END
GO
3.执行下面的语句,并查看结果
复制代码代码如下:
select dbo.AggregateString(Id),Id from AggregationTable
group by Id
结果为:
Id Name
1 赵孙李
2 钱周
|