关于SQLServer2005的学习笔记——自定义分组的实现

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:
对于自定义分组,一向是比较烦琐的,幸好 SQLServer2005 提供了 FOR XML PATH 的语法能够很方便的解决该问题,同时采用自定义函数的方式还能够更方便的进行扩展; Oracle10g 以后提供了一个 wmsys.wm_concat 函数,也可以起到类似的作用。
 
下面以 SQLServer2005 自带的 AdventureWorks 数据库 中的 2 个表为例
HumanResources.Department       -- 部门信息表
HumanResources.EmployeeDepartmentHistory  -- 部门员工对照表
 
-- 使用自定义函数的方式
SELECT groupname,dbo.fn_concatemployees(departmentid) employeesconcat FROM HumanResources.Department
CREATE FUNCTION fn_concatemployees(@departmentid INT) RETURNS VARCHAR(1000)
AS
BEGIN
         DECLARE @employeeidcancat AS VARCHAR(1000);
         SET @employeeidcancat='';
         SELECT @employeeidcancat=@employeeidcancat+CAST(employeeid AS VARCHAR(10))+';'
           FROM HumanResources.EmployeeDepartmentHistory
           WHERE  departmentid=@departmentid;
         RETURN @employeeidcancat;
END 
 
 
-- 使用 SQLServer2005 的 FOR XML PATH 方式
SELECT groupname,
         (SELECT CAST(o.employeeid AS VARCHAR(10))+';' AS [text()]
            FROM HumanResources.EmployeeDepartmentHistory o
           WHERE o.departmentid=c.departmentid
           ORDER BY employeeid
             FOR XML PATH('')) AS employeesconcat
  FROM HumanResources.Department c 
 
 
-- 在 Oracle10g 中采用 wmsys.wm_concat 方式
SELECT groupname,wmsys.wm_concat(employeeid) employeesconcat
  FROM EmployeeDepartmentHistory
  GROUP BY groupname; 
 




本文转自baoqiangwang51CTO博客,原文链接:http://blog.51cto.com/baoqiangwang/310446 ,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
28天前
|
SQL
sql server模糊查询、分组
sql server模糊查询、分组
12 1
|
11月前
|
SQL
sql server模糊查询、分组
sql server模糊查询、分组
131 0
|
SQL 存储 程序员
【Sql Server】sql语句文件组分区函数分组方案对应分区表的简单步骤
本篇文章中,主要讲讲sql server数据库中通过sql语句方式对组分区函数的使用 在实际项目中,sql server数据库中有分区的概念,因为在一个表存在大量数据的情况下,需要通过分区方式保存数据来提供查询性能
152 0
|
SQL 程序员 开发工具
【Sql Server】基础之分组查询重复出现多条记录的SQL语句,以及group by和having、min函数运用
基础之分组查询重复出现多条记录的SQL语句,以及group by和having、min函数运用
430 0
【Sql Server】基础之分组查询重复出现多条记录的SQL语句,以及group by和having、min函数运用
|
SQL 存储 数据库
数据库原理与应用(SQL Server)笔记 第八章 用户自定义数据类型与变量
数据库原理与应用(SQL Server)笔记 第八章 用户自定义数据类型与变量
数据库原理与应用(SQL Server)笔记 第八章 用户自定义数据类型与变量
|
SQL 监控 Go
SQL Server如何定位自定义标量函数被那个SQL调用次数最多浅析
原文:SQL Server如何定位自定义标量函数被那个SQL调用次数最多浅析 前阵子遇到一个很是棘手的问题,监控系统DPA发现某个自定义标量函数被调用的次数非常高,高到一个离谱的程度。然后在Troubleshooting这个问题的时候,确实遇到了一些问题让我很是纠结,下文是解决问题过程的一点思索和尝试,如果你有更好的思路和解决方法,也请多多指教。
956 0
|
SQL
SQL Server中使用自定义指定顺序排序
原文:SQL Server中使用自定义指定顺序排序 比如需要对SQL表中的字段NAME进行如下的排序:张三(Z)李四(L)王五(W)赵六(Z)   如果想按 “ 张三、李四、王五、赵六”的顺序排序,则可以使用以下语句: order by charindex(NAME,‘张三李四王五赵六’)
3060 0
|
SQL 存储 .NET
SQL Server CLR 使用 C# 自定义存储过程和触发器
原文:SQL Server CLR 使用 C# 自定义存储过程和触发器 这一篇博客接着上一篇博客继续介绍 SQL CLR Stored Procedure 和 CLR Trigger, 上一篇博客介绍了 SQL CLR Function 的使用,以及 CLR 程序集的注册和 CLR Function 的注册。
928 0
|
SQL 索引
SQL Server 分组后取Top N
近日,工作中突遇一需求:将一数据表分组,而后取出每组内按一定规则排列的前N条数据。乍想来,这本是寻常查询,无甚难处。可提笔写来,终究是困住了笔者好一会儿。冥思苦想,遍查网络,不曾想这竟然是SQL界的一个经典话题。
3020 0
|
Web App开发 SQL Go
SQL Server 2008 R2——分组取前几名
版权声明:本文为博主原创文章 未经许可不得转载   请通过右侧公告中的“联系邮箱(wlsandwho@foxmail.com)”联系我 未经作者授权勿用于学术性引用。 未经作者授权勿用于商业出版、商业印刷、商业引用以及其他商业用途。
1075 0