最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

数据库中分组第N条记录获取方式

来源:动视网 责编:小采 时间:2020-11-09 15:58:29
文档

数据库中分组第N条记录获取方式

数据库中分组第N条记录获取方式:欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 数据库中分组第N条记录获取方式 第一条记录Oracle: 1 2 3 select * from ( select row_number() over(partition by num order by num) gid,* from tb) tmp
推荐度:
导读数据库中分组第N条记录获取方式:欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 数据库中分组第N条记录获取方式 第一条记录Oracle: 1 2 3 select * from ( select row_number() over(partition by num order by num) gid,* from tb) tmp


欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 数据库中分组第N条记录获取方式 第一条记录Oracle: 1 2 3 select * from ( select row_number() over(partition by num order by num) gid,* from tb) tmp where gid=1; ROW_NUMBER() 说明:返回

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入

  数据库中分组第N条记录获取方式

  第一条记录Oracle:

1

2

3

select * from(select row_number() over(partition by num order by num) gid,* from tb) tmp where gid=1;

ROW_NUMBER()

  说明:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。

  语法:ROW_NUMBER () OVER ( [ ] ) 。

  备注:ORDER BY 子句可确定在特定分区中为行分配唯一 ROW_NUMBER 的顺序。

  参数: :将 FROM 子句生成的结果集划入应用了 ROW_NUMBER 函数的分区。

  :确定将 ROW_NUMBER 值分配给分区中的行的顺序。

  返回类型:bigint 。

  示例:

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

48

49

50

51

52

53

54

/*以下示例将根据年初至今的销售额,返回 AdventureWorks 中销售人员的 ROW_NUMBER。*/

USE AdventureWorks

GO

SELECT c.FirstName, c.LastName, ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS 'Row Number', s.SalesYTD, a.PostalCode

FROM Sales.SalesPerson s JOIN Person.Contact c on s.SalesPersonID = c.ContactID

JOIN Person.Address a ON a.AddressID = c.ContactID

WHERE TerritoryID IS NOT NULL AND SalesYTD <> 0

/*

FirstName LastName Row Number SalesYTD PostalCode

--------- ---------- ---------- ------------ ----------------------------

Shelley Dyck 1 5200475.2313 98027

Gail Erickson 2 5015682.3752 98055

Maciej Dusza 3 4557045.0459 98027

Linda Ecoffey 4 3857163.6332 98027

Mark Erickson 5 3827950.238 98055

Terry Eminhizer 6 3587378.4257 98055

Michael Emanuel 7 3189356.2465 98055

Jauna Elson 8 3018725.4858 98055

Carol Elliott 9 2811012.7151 98027

Janeth Esteves 10 2241204.0424 98055

Martha Espinoza 11 1931620.1835 98055

Carla Eldridge 12 1764938.9859 98027

Twanna Evans 13 1758385.926 98055

(13 行受影响)

*/

/*以下示例将返回行号为 50 到 60(含)的行,并以 OrderDate 排序。*/

USE AdventureWorks;

GO

WITH OrderedOrders AS

(SELECT SalesOrderID, OrderDate,

ROW_NUMBER() OVER (order by OrderDate)as RowNumber

FROM Sales.SalesOrderHeader )

SELECT *

FROM OrderedOrders

WHERE RowNumber between 50 and 60;

/*

SalesOrderID OrderDate RowNumber

------------ ----------------------- --------------------

43708 2001-07-03 00:00:00.000 50

43709 2001-07-03 00:00:00.000 51

43710 2001-07-03 00:00:00.000 52

43711 2001-07-04 00:00:00.000 53

43712 2001-07-04 00:00:00.000 54

43713 2001-07-05 00:00:00.000 55

43714 2001-07-05 00:00:00.000 56

43715 2001-07-05 00:00:00.000 57

43716 2001-07-05 00:00:00.000 58

43717 2001-07-05 00:00:00.000 59

43718 2001-07-06 00:00:00.000 60

(11 行受影响)

*/

文档

数据库中分组第N条记录获取方式

数据库中分组第N条记录获取方式:欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 数据库中分组第N条记录获取方式 第一条记录Oracle: 1 2 3 select * from ( select row_number() over(partition by num order by num) gid,* from tb) tmp
推荐度:
标签: 记录 分组 进入
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top