中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > MSSQL Server
深度探讨SQL Server 2005 窗口函数
作者:佚名 时间:2007-06-26 14:43 出处:builder.com 责编:月夜寒箫
              摘要:深度探讨SQL Server 2005 窗口函数

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都得到一个窗口。

 

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

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有