


Sql server 2005数据库列表合计
添加时间:2013-4-17 17:36:02
添加:
思海网络
在微软的SQL Server 论坛里面有一个很常见的问题就是,SQL Server 2005是否有与SUM类似的集合函数,但是是用于字符串的集合的。例如,假设一个数据库有如下的表和数据::
CREATE TABLE Strings
(
String VARCHAR(20)
)
(
String VARCHAR(20)
)
INSERT Strings VALUES ('A')
INSERT Strings VALUES ('B')
INSERT Strings VALUES ('C')
有可能要在这个表上用到如下的集合,以便生成一个字符串的列表:
SELECT LISTAGG(String)
FROM Strings
输出:
'A, B, C'
虽然这个合计没有构建在SQL Server 2005的内部,新的系统仍然引入了一种可以轻松达到这个功能的方式。最常见的方式就是使用新的CLR用户自定义合计(UDA)。不幸的是,用户自定义合计有8000个字节的限制,这大大限制了它们在对大集合进行合计的应用。
另一种在SQL Server 2005中达到目标的方式就是新的FOR XML PATH函数的副产品。通过制定空的路径,就有可能产生一个类似字符串合计的函数来:
SELECT String + ', ' AS [text()]
FROM Strings
ORDER BY String
FOR XML PATH('')
有关这个技术的更多信息,可以在Aaron Bertrand 的ASP FAQ http://www.aspfaq.com/网站上找到。
关键字:Sql server 2005、数据库
新文章:
- CentOS7下图形配置网络的方法
- CentOS 7如何添加删除用户
- 如何解决centos7双系统后丢失windows启动项
- CentOS单网卡如何批量添加不同IP段
- CentOS下iconv命令的介绍
- Centos7 SSH密钥登陆及密码密钥双重验证详解
- CentOS 7.1添加删除用户的方法
- CentOS查找/扫描局域网打印机IP讲解
- CentOS7使用hostapd实现无AP模式的详解
- su命令不能切换root的解决方法
- 解决VMware下CentOS7网络重启出错
- 解决Centos7双系统后丢失windows启动项
- CentOS下如何避免文件覆盖
- CentOS7和CentOS6系统有什么不同呢
- Centos 6.6默认iptable规则详解