解析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