赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索

深度探讨SQL Server 2005 窗口函数

发布时间:2007.05.08 04:54     来源:builder.com    作者:builder.com

SQL Server 2005中的窗口函数(window function)与微软Windows无关;相反,它们建立数据窗口。窗口函数帮助你迅速查看不同级别的聚合,通过它可以非常方便地恢复累计总数、移动平均值、以及执行其它计算。

一个SQL Server窗口是对函数应用的行的分区。你使用OVER(…)子句指定一个窗口,你可以对任何一个聚合函数应用这个子句。通常来说,你把数据分成几个组,但OVER()的自变量可选。

USE AdventureWorks2;
GO
SELECT SalesOrderID, ProductID, 
OrderQty AS 'Item Qty',SUM(OrderQty) 
OVER(PARTITION BY SalesOrderID) AS 'Total Qty',
AVG(OrderQty) OVER(PARTITION BY SalesOrderID) 
AS 'Average Qty',
COUNT(OrderQty) OVER(PARTITION BY SalesOrderID) 
AS 'Total Count',
MIN(OrderQty) OVER(PARTITION BY SalesOrderID) 
AS 'Minimum Count',
MAX(OrderQty) OVER(PARTITION BY SalesOrderID) AS 
'Maximum Count',LineTotal,
AVG(LineTotal) OVER(PARTITION BY SalesOrderID) AS 
'Average Amount',
SUM(LineTotal) OVER(PARTITION BY SalesOrderID) AS 
'Total Amount',(LineTotal/SUM(LineTotal) 
OVER(PARTITION BY SalesOrderID)) * 100 AS 
'Percent'FROM Sales.SalesOrderDetail WHERE 
SalesOrderID = 43664ORDER BY ProductID
GO

列表A

列表B

列表A说明如何一次搜集几个聚集,甚至根据聚合进行其它计算。这样就可得到列表B中的结果集。我把结果集限定为一个单独的OrderID,那么查询将只产生一个窗口。你可以用各种方式修改子句,如使用一个IN()子句列出一组特殊的顺序,或使用一个BETWEEN子句推导一个顺序范围内的统计值。最后你指定的每个OrderID都得到一个窗口。

窗口函数功能非常强大,建立起来也十分容易。你可以使用这个技巧立即搜索到大量统计值。这个教程中的例子指出,你可以在单独一个查询中搜索任何统计值集合。(T006)

相关文章:

深入了解SQLServer系统数据库工作原理

SQL Server中优化其索引的妙招简介


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 推荐:SQL Server 安全规划全攻略 (04-30) · SQL Server 2000安全配置完全攻略 (04-30)
· SQL Server 2005 五个动态管理对象 (04-29) · 分析 SQL Server 的内存为何不断增加 (04-29)
· 如何进行 SQL Server 批理修改权限 (04-29) · 如何进行 SQL Server 批理修改权限 (04-28)
· SQL Server 跨服务器连接的多种方法 (04-28) · 在SQL Server计算机上运行病毒扫描软件 (04-28)
· 在 SQL Server数据库开发中的十大问题 (04-26) · 向外扩展SQL Server 实现更高扩展性 (04-26)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管