国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Sql Server - SqlServer 2000、2005分頁存儲(chǔ)過程整理

SqlServer 2000、2005分頁存儲(chǔ)過程整理

2020-04-12 14:36MSSQL教程網(wǎng) Sql Server

這篇文章主要介紹了SqlServer 2000、2005分頁存儲(chǔ)過程整理,本文給出了4個(gè)實(shí)現(xiàn)版本,還給出二分分頁過程,需要的朋友可以參考下

sql server 2005的分頁存儲(chǔ)過程分3個(gè)版本,一個(gè)是沒有優(yōu)化過的,一個(gè)是優(yōu)化過的,最后一個(gè)支持join的,sql server 2000的分頁存儲(chǔ)過程,也可以運(yùn)行在sql server 2005上,但是性能沒有sql server 2005的版本好。

在最后 我還附帶了一個(gè)二分法的分頁存儲(chǔ)過程,也很好用的說哈~~

1.SqlServer 2005:

?
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
 
CREATE proc [dbo].[up_Page2005]
 @TableName varchar(50),    --表名
 @Fields varchar(5000) = '*'--字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語句(不用加where)
 @pageSize int,          --每頁多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁
 @TotalPage int output      --返回總頁數(shù)
as
begin
 
  Begin Tran --開始事務(wù)
 
  Declare @sql nvarchar(4000);
  Declare @totalRecord int;
 
  --計(jì)算總記錄數(shù)
 
  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'select @totalRecord = count(*) from ' + @TableName
  else
    set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' with(nolock) where ' + @sqlWhere
 
  EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)
 
  --計(jì)算總頁數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)
 
  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' with(nolock) where ' + @SqlWhere
 
  --處理頁數(shù)超出范圍情況
  if @PageIndex<=0
    Set @pageIndex = 1
 
  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage
 
   --處理開始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int
 
  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1
 
  --繼續(xù)合成sql語句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql
  Exec(@Sql)
  ---------------------------------------------------
  If @@Error <> 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
end

 

2.Sql Server 2005:

?
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/****** 對(duì)象: StoredProcedure [dbo].[up_Page2005V2]  腳本日期: 05/21/2008 11:27:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:    <Author,,Name>
-- Create date: <Create Date,,>
-- Description:  <Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[up_Page2005V2]
  @TableName varchar(50),    --表名
 @Fields varchar(5000) = '*'--字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語句(不用加where)
 @pageSize int,          --每頁多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁
 @totalRecord int = 0,
 @TotalPage int output      --返回總頁數(shù)
AS
BEGIN
 
   Begin Tran --開始事務(wù)
 
  Declare @sql nvarchar(4000);
 
  if @totalRecord<=0 begin
    --計(jì)算總記錄數(shù)
 
    if (@SqlWhere='' or @sqlWhere=NULL)
      set @sql = 'select @totalRecord = count(*) from ' + @TableName
    else
      set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' with(nolock) where ' + @sqlWhere
 
    EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)
  end
 
  --計(jì)算總頁數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)
 
  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' with(nolock) where ' + @SqlWhere
 
  --處理頁數(shù)超出范圍情況
  if @PageIndex<=0
    Set @pageIndex = 1
 
  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage
 
   --處理開始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int
 
  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1
 
  --繼續(xù)合成sql語句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql
  Exec(@Sql)
  ---------------------------------------------------
  If @@Error <> 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
END
 
GO

 

3.Sql Server 2005:

?
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/****** 對(duì)象: StoredProcedure [dbo].[up_Page2005V2_Join]  腳本日期: 05/21/2008 11:27:30 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[up_Page2005V2_Join]
  @TableName varchar(150),    --表名
 @Fields varchar(5000) = '*'--字段名(全部字段為*)
 @OrderField varchar(5000),    --排序字段(必須!支持多字段)
 @sqlWhere varchar(5000) = Null,--條件語句(不用加where)
 @pageSize int,          --每頁多少條記錄
 @pageIndex int = 1 ,      --指定當(dāng)前為第幾頁
 @totalRecord int = 0,
 @TotalPage int output      --返回總頁數(shù)
AS
BEGIN
 
   Begin Tran --開始事務(wù)
 
  Declare @sql nvarchar(4000);
 
  if @totalRecord<=0 begin
    --計(jì)算總記錄數(shù)
 
    if (@SqlWhere='' or @sqlWhere=NULL)
      set @sql = 'select @totalRecord = count(*) from ' + @TableName
    else
      set @sql = 'select @totalRecord = count(*) from ' + @TableName + ' where ' + @sqlWhere
 
    EXEC sp_executesql @sql,N'@totalRecord int OUTPUT',@totalRecord OUTPUT--計(jì)算總記錄數(shù)
  end
 
  --計(jì)算總頁數(shù)
  select @TotalPage=CEILING((@totalRecord+0.0)/@PageSize)
 
  if (@SqlWhere='' or @sqlWhere=NULL)
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName
  else
    set @sql = 'Select * FROM (select ROW_NUMBER() Over(order by ' + @OrderField + ') as rowId,' + @Fields + ' from ' + @TableName + ' where ' + @SqlWhere
 
  --處理頁數(shù)超出范圍情況
  if @PageIndex<=0
    Set @pageIndex = 1
 
  if @pageIndex>@TotalPage
    Set @pageIndex = @TotalPage
 
   --處理開始點(diǎn)和結(jié)束點(diǎn)
  Declare @StartRecord int
  Declare @EndRecord int
 
  set @StartRecord = (@pageIndex-1)*@PageSize + 1
  set @EndRecord = @StartRecord + @pageSize - 1
 
  --繼續(xù)合成sql語句
  set @Sql = @Sql + ') as t where rowId between ' + Convert(varchar(50),@StartRecord) + ' and ' + Convert(varchar(50),@EndRecord)
   print @sql
 
  Exec(@Sql)
  ---------------------------------------------------
  If @@Error <> 0
   Begin
    RollBack Tran
    Return -1
   End
   Else
   Begin
    Commit Tran
    Return @totalRecord ---返回記錄總數(shù)
   End
END

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91免费在线视频 | 99国产精品99久久久久久 | 国产精品自产拍在线观看 | 色天天综合网 | 国产精彩视频 | 水卜樱一区二区av | 亚洲欧美激情在线 | 色九九 | 国产一级毛片一级 | av片免费 | 亚洲午夜免费视频 | 亚洲欧洲av在线 | 国产精品免费一区 | 日韩在线 | 免费久久久久 | 91人人| 国产成人精品免高潮在线观看 | 色综合天天综合网国产成人网 | 国产精品爱久久久久久久 | 精品日韩 | 在线激情网站 | 日本一区二区免费视频 | 精品久久中文字幕 | 麻豆产精国品免费入口 | 国产一区二区在线免费观看 | 美女一级毛片 | 国产最新视频 | 成人av在线网 | 亚洲精品二区三区 | 无码日韩精品一区二区免费 | 中文字幕在线观看一区二区三区 | 国产毛片网站 | 中文字幕视频在线 | 日韩中文字幕在线视频 | 黄色日本视频 | 午夜男人天堂 | 天天射天天 | 欧美男人天堂 | 亚洲国产精品久久人人爱 | 一级片在线免费观看视频 | 久久九九 |