SQL Server 2012  开窗函数

 更新时间:2017年01月29日 10:42:07   作者:i-shanghai  
这篇文章主要介绍了SQL Server 2012 开窗函数功能的实例代码,具体代码如下所示

废话不多说了,直接给大家贴代码了,具体代码如下所示:

-- 开窗函数:在结果集的基础上进一步处理(聚合操作)
-- Over函数,添加一个字段显示最大年龄
SELECT * ,
    MAX(StuAge) OVER ( ) MaxStuAge
FROM  dbo.Student;
-- Over函数,添加一个字段显示总人数
SELECT * ,
    COUNT(StuID) OVER ( ) StuCount
FROM  dbo.Student;
-- Partition By 分组统计数量
-- 根据性别分组后,统计
SELECT COUNT(*) OVER ( PARTITION  BY StuSex ) ,
    *
FROM  dbo.Student;
-- 根据班级分组后,统计、排序
SELECT COUNT(*) OVER ( PARTITION  BY Class ORDER BY Height) ,
    *
FROM  dbo.Student;
-- Over函数,添加一个字段显示平均身高
SELECT * ,
    AVG(Height) OVER ( ) AgeHeight
FROM  dbo.Student;
--Row_Rumber()
SELECT ROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber ,
    *
FROM  dbo.Student
--Row_Rumber() 实现分页效果
;
WITH  T AS ( SELECT  ROW_NUMBER() OVER ( ORDER BY StuID DESC ) RowNumber ,
            *
        FROM   dbo.Student
       )
  SELECT *
  FROM  T
  WHERE  T.RowNumber BETWEEN 1 AND 3;
--Rank() 排名函数,名次相同,跳过
SELECT RANK() OVER ( ORDER BY Height ) ,
    *
FROM  dbo.Student;
--DENSE_Rank() 排名函数,名次相同不跳过
SELECT DENSE_RANK() OVER ( ORDER BY Height ) ,
    *
FROM  dbo.Student;
-- NTILE()函数,参数:记录总数/划分区域 = 每个区域数组,把记录序号放进数组 (平均分组)
SELECT NTILE(3) OVER ( ORDER BY StuSex ) ,
    *
FROM  dbo.Student;

以上所述是小编给大家介绍的SQL Server 2012  开窗函数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

  • SQL Server控制语句的基本应用

    SQL Server控制语句的基本应用

    本篇文章介绍了,SQL Server控制语句的基本应用。需要的朋友参考下
    2013-04-04
  • 企业管理器备份和还原SQL Server数据库

    企业管理器备份和还原SQL Server数据库

    本文我们主要介绍了利用SQL Server数据库的企业管理器来备份和还原数据库的方法以及每日自动备份数据库的设置,希望能够对您有所帮助。
    2015-08-08
  • 解析SQLServer2005的Top功能

    解析SQLServer2005的Top功能

    本篇文章是对SQLServer2005的Top功能进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 详解SQL Server中的事务与锁问题

    详解SQL Server中的事务与锁问题

    在数据库方面,对于非DBA的程序员来说,事务与锁是一大难点,针对该难点,本篇文章试图采用图文的方式来与大家一起探讨sqlserver事务与锁问题
    2018-02-02
  • sql server使用nest typeorm实现索引的方式

    sql server使用nest typeorm实现索引的方式

    本文通过示例演示了如何使用TypeORM库在SQL Server中创建不同类型的索引,分为普通索引,唯一索引,复合索引和空间索引,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • SQL Server事务日志已满的三种解决方案

    SQL Server事务日志已满的三种解决方案

    我们安装数据库后,系统会默认把数据库文件和数据库日志文件最大设为500MB,当然你中途可以更改这个限制,当日志文件接近最大值时,继续使用数据库会提示:事务日志已满,本文给出了三种解决方案,需要的朋友可以参考下
    2023-11-11
  • sql 2000 无法执行查询,因为一些文件缺少或未注册"的解决方法

    sql 2000 无法执行查询,因为一些文件缺少或未注册"的解决方法

    在SQL server 2000中打开表查看数据的时候,提示说无法执行查询,因为一些文件缺少或未注册用查询分析器可以查看数据,重装了sql2000也没有用,这里分享下解决方法
    2014-01-01
  • SQL多表连接查询实例分析(详细图文)

    SQL多表连接查询实例分析(详细图文)

    本文主要列举两张和三张表来讲述多表连接查询,需要的朋友可以参考下
    2013-09-09
  • SQLServer数据库游标的具体使用

    SQLServer数据库游标的具体使用

    本文主要介绍了SQLServer数据库游标的具体使用,游标通常用于需要逐行处理数据的情况,例如对每一行数据进行特定的计算或更新操作,下面就一起来了解一下
    2024-08-08
  • 深入分析MSSQL数据库中事务隔离级别和锁机制

    深入分析MSSQL数据库中事务隔离级别和锁机制

    事务隔离级别简单的说,就是当激活事务时,控制事务内因SQL语句产生的锁定需要保留多入,影响范围多大,以防止多人访问时,在事务内发生数据查询的错误。设置事务隔离级别将影响整条连接。
    2014-08-08

最新评论