zoukankan      html  css  js  c++  java
  • sql 2005 Tsql脚本增强 集合贴

    SQL Server 2005中的窗口函数(window function)与微软Windows无关;相反,它们建立数据窗口。窗口函数帮助你迅速查看不同级别的聚合,通过它可以非常方便地恢复累计总数、移动平均值、以及执行其它计算。 一个SQL Server窗口是对函数应用的行的分区。你使用OVER(…)子句指定一个窗口,你可以对任何一个聚合函数应用这个子句。通常来说,你把数据分成几个组,但OVER()的自变量可选。

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

    USE AdventureWorks;
    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 = 43664
    ORDER BY ProductIDSQL2005新增函数,排名函数

    --sql2005排名函数
    SELECT ROW_NUMBER() OVER (ORDER BY id) AS 行号,* FROM sysobjects

    --在2000版本中要这样实现
    SELECT Identity(int,1,1) AS Num,* INTO #temptable FROM TableName
    SELECT*FROM #temptable
    DROP TABLE #temptable排名函数备注说明:

    RANK()函数保留列表中行的位置序号,对于每个重复值,这个函数跳过下面值,于是下一个不重复的值就保留在了正确的位置上了。

    DENSE_RANK()函数工作方式是相同的,不过它不跳过每个连带之后的数字,这样就不会有数字消失了,不过排列序号位置出现连带的地方就丢失了。 举例(在做学生成绩排名之类的时非常有作用。这两个非常有用)

    NTITLE(n)函数,将结果切分为有限数量的排列组。更多示例见联机丛书.

    示例2:在SQL2005中处理交叉表: 关键字:PIVOT 和 UNPIVOT 运算符

    DECLARE @t TABLE ([日期] datetime,[时间] varchar(20),[售货金额] int)
    insert into @t select '2006-01-02','早上',50
    union all select '2006-01-02','中午',20
    union all select '2006-01-02','晚上',30
    union all select '2006-01-02','零晨',40
    union all select '2006-01-03','早上',40
    union all select '2006-01-03','中午',60
    union all select '2006-01-03','晚上',50
    union all select '2006-01-03','零晨',50
    union all select '2006-01-04','早上',80
    union all select '2006-01-04','中午',60
    union all select '2006-01-04','晚上',20
    union all select '2006-01-04','零晨',40

    --查询

    select * ,金额小计=(select sum(售货金额) from @t where 日期=PT.日期 ) from @t as TAB
    PIVOT
    ( max([售货金额])
      for [时间] in ([早上],[中午],[晚上],[零晨])
    ) as PT

    --列不确定时:

    DECLARE @S VARCHAR(MAX)
    SET @S=''
    SELECT @S=@S+',['+时间+']' FROM @t
      GROUP BY 时间
    SET @S=STUFF(@S,1,1,'')
    EXEC('
    select 日期,'+@S+',金额小计=(select sum(售货金额) from @t where 日期=PT.日期 ) from @t as TAB
    PIVOT
    ( max(售货金额)
      for 时间 in ('+@S+')
    ) as PT
    ')SQL2005中拆分列值,使用OUTER APPLY运算符。见示例:

    DECLARE @t TABLE ([日期] datetime,[时间] varchar(20),[售货金额] int)
    insert into @t select '2006-01-02','早上',50
    union all select '2006-01-02','中午',20
    union all select '2006-01-02','晚上',30
    union all select '2006-01-02','零晨',40
    union all select '2006-01-03','早上',40
    union all select '2006-01-03','中午',60
    union all select '2006-01-03','晚上',50
    union all select '2006-01-03','零晨',50
    union all select '2006-01-04','早上',80
    union all select '2006-01-04','中午',60
    union all select '2006-01-04','晚上',20
    union all select '2006-01-04','零晨',40

    --查询

    select * ,金额小计=(select sum(售货金额) from @t where 日期=PT.日期 ) from @t as TAB
    PIVOT
    ( max([售货金额])
      for [时间] in ([早上],[中午],[晚上],[零晨])
    ) as PT

    /*结果

    日期                早上    中午   晚上   零晨   金额小计
    ----------------------- ----------- ----------- ----------- ----------- -----------
    2006-01-02 00:00:00.000 50          20          30          40          140
    2006-01-03 00:00:00.000 40          60          50          50          200
    2006-01-04 00:00:00.000 80          60          20          40          200  */SQL2005中合并列值,见示例

    -- 示例数据
    DECLARE @t TABLE(id int, value varchar(10))
    INSERT @t SELECT 1, 'aa'
    UNION ALL SELECT 1, 'bb'
    UNION ALL SELECT 2, 'aaa'
    UNION ALL SELECT 2, 'bbb'
    UNION ALL SELECT 2, 'ccc'

    SELECT *
    FROM(
    SELECT DISTINCT
    id
    FROM @t
    )A
    OUTER APPLY(
    SELECT [values]= STUFF(REPLACE(REPLACE(
    (
    SELECT value FROM @t N
    WHERE id = A.id
    FOR XML AUTO
    ), '<N value="', ','), '"/>', ''), 1, 1, '')
    )N

    /* 结果
    id          values
    ----------- ----------------
    1           aa,bb
    2           aaa,bbb,ccc */更多见:http://blog.csdn.net/itblog/archive/2006/06/05/774363.aspx

    sql 2005 express版本,需要加增加图形管理器,下载:http://www.microsoft.com/downloads/details.aspx?FamilyID=6053c6f8-82c8-479c-b25b-9aca13141c9e&DisplayLang=zh-cn

    sql2005导入导出向导: C:\Program Files\Microsoft SQL Server\90\DTS\Binn\DTSWizard.exe 可自己在工具--外部工具中--添加引用.好比快捷方式。


    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhou__zhou/archive/2007/06/17/1655352.aspx

  • 相关阅读:
    常用WebService一览表
    Generic Data Access Objects [转]
    spring hibernate properties详解
    SpringMVC常用基础知识【转】
    向PLSQL导入txt,csv文件
    打印金字塔图案
    经常使用的文件工具类
    求两个数的最大公约数
    155个建议笔记1
    用Tika读取文件(不需要考虑文件格式)
  • 原文地址:https://www.cnblogs.com/0000/p/1516321.html
Copyright © 2011-2022 走看看