解析SQL Server 2005 溢用之:合并列值

作者:zise 时间:2009-01-23 14:08:00 

很多人可能发现,无论是在sql 2000, 还是在 sql 2005 中,都没有提供字符串的聚合函数, 所以, 当我们在处理下列要求时,会比较麻烦, 但在 SQL Server 2005中, 这种情况得到了改善, 我们可以轻松地完成这项处理。

问题描述:

无论是在sql 2000, 还是在 sql 2005 中,
都没有提供字符串的聚合函数, 所以, 当
我们在处理下列要求时,会比较麻烦:

有表tb, 如下:

id    value

----- ------

1     aa

1     bb

2     aaa

2     bbb

2     ccc

需要得到结果:

id     values

------ -----------

1      aa,bb

2      aaa,bbb,ccc

即, group by id, 求 value 的和(字符串相加)
 
1. 旧的解决方法

创建处理函数

CREATE FUNCTION dbo.f_str(@id int)

RETURNS varchar(8000)

AS

BEGIN

    DECLARE @r varchar(8000)

    SET @r = ''

    SELECT @r = @r + ',' + value

    FROM tb

    WHERE id=@id

    RETURN STUFF(@r, 1, 1, '')

END

GO

-- 调用函数

SELECt id, values=dbo.f_str(id)

FROM tb

GROUP BY id

标签:
0
投稿

猜你喜欢

  • 功能强大,代码简单的管理菜单

    2008-07-11 16:52:00
  • JQuery获取表单值

    2009-11-19 13:17:00
  • Oracle 数据库导出(exp)导入(imp)说明

    2009-03-06 10:49:00
  • Dreaweaver MX 2004新功能:图片处理

    2010-09-02 12:38:00
  • Javascript 回调和事件(翻译)

    2009-03-28 11:47:00
  • 设计原则-控件Balloons(气球状提示)

    2009-08-15 12:34:00
  • SQL Server中如何快速获取表的记录总数

    2008-12-05 15:59:00
  • 利用MySQL加密函数保护Web网站敏感数据

    2008-12-17 16:11:00
  • javascript基础之indexOf函数

    2008-06-25 13:28:00
  • 设计的商业价值

    2009-08-13 14:43:00
  • 整理几个js日历源代码

    2008-01-03 13:13:00
  • SQL 特殊语句(学习笔记)

    2012-06-06 19:51:33
  • 巧用Dreamweaver MX设计导航栏特效

    2009-07-10 13:17:00
  • Opera下cloneNode的bug

    2007-11-23 11:40:00
  • 认识延迟时间为 0 的 setTimeout

    2008-04-04 16:37:00
  • CSS绝对定位在宽屏分辨率下错位

    2009-07-28 12:24:00
  • ORACLE数据库查看执行计划的方法

    2012-06-06 20:15:52
  • javascript 函数调用的对象和方法

    2010-07-02 12:25:00
  • 如何提升JavaScript的运行速度(函数篇)

    2010-05-17 13:27:00
  • 在SQL Server中使用索引的技巧

    2009-02-24 17:50:00
  • asp之家 网络编程 m.aspxhome.com