SQL Server 2012 开窗函数

这篇文章主要介绍了SQL Server 2012 开窗函数功能的实例代码,具体代码如下所示

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

— 开窗函数:在结果集的基础上进一步处理(聚合操作)

— 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 开窗函数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

原文链接:http://www.cnblogs.com/i-shanghai/p/6351346.html

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/25611/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022-09-25 4:11:58
下一篇 2022-09-25 4:12:04

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!