亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > sqlserver 高性能分頁實現(xiàn)分析

sqlserver 高性能分頁實現(xiàn)分析

熱門標(biāo)簽:al智能電話機器人 最新人工智能電銷機器人 數(shù)字匠心電銷機器人 如何做地圖標(biāo)注圖鋪 成都電話外呼系統(tǒng)一般多少錢 陜西電銷外呼系統(tǒng)好用嗎 蘭州語音外呼系統(tǒng)運營商 沒聽見電話機器人幫你接 銀川高頻外呼回?fù)芟到y(tǒng)多少錢
先來說說實現(xiàn)方式:
1、我們來假定Table中有一個已經(jīng)建立了索引的主鍵字段ID(整數(shù)型),我們將按照這個字段來取數(shù)據(jù)進行分頁。
2、頁的大小我們放在@PageSize中
3、當(dāng)前頁號我們放在@CurrentPage中
4、如何讓記錄指針快速滾動到我們要取的數(shù)據(jù)開頭的那一行呢,這是關(guān)鍵所在!有了Set RowCount,我們就很容易實現(xiàn)了。
5、如果我們成功地滾動記錄指針到我們要取的數(shù)據(jù)的開頭的那一行,然后我們把那一行的記錄的ID字段的值記錄下來,那么,利用Top和條件,我們就很容易的得到指定頁的數(shù)據(jù)了。當(dāng)然,有了Set RowCount,我們難道還用Top么?
看看Set Rowcount怎么來幫我們的忙吧:

復(fù)制代碼 代碼如下:

Declare @ID int
Declare @MoveRecords int

--@CurrentPage和@PageSize是傳入?yún)?shù)
Set @MoveRecords=@CurrentPage * @PageSize+1

--下面兩行實現(xiàn)快速滾動到我們要取的數(shù)據(jù)的行,并把ID記錄下來
Set Rowcount @MoveRecords
Select @ID=ID from Table1 Order by ID

Set Rowcount @PageSize
--最恨為了減少麻煩使用*了,但是在這里為了說明方便,暫時用一下
Select * From Table1 Where ID>=@ID Order By ID
Set Rowcount 0

大家可以試試看,在一個1千W記錄的表里面,一下子方翻頁到第100頁(每頁100條),看看有多快!

因為平常 倒序 排的比較多,上面也很好改。
將 Order by ID 改成 Order by ID DESC
將 Where ID>=@ID Order By ID 改成 Where ID=@ID Order By ID DESC
就可以了.
復(fù)制代碼 代碼如下:

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
Create PROCEDURE [dbo].[Tag_Page_Name_Select]
-- 傳入最大顯示紀(jì)錄數(shù)和當(dāng)前頁碼
@MaxPageSize int,
@PageNum int,
-- 設(shè)置一個輸出參數(shù)返回總紀(jì)錄數(shù)供分頁列表使用
@Count int output
AS
BEGIN
SET NOCOUNT ON;

DECLARE
-- 定義排序名稱參數(shù)
@Name nvarchar(50),
-- 定義游標(biāo)位置
@Cursor int
-- 首先得到紀(jì)錄總數(shù)
Select @Count = count(tag_Name)
FROM [viewdatabase0716].[dbo].[view_tag];
-- 定義游標(biāo)需要開始的位置
Set @Cursor = @MaxPageSize*(@PageNum-1)+1
-- 如果游標(biāo)大于紀(jì)錄總數(shù)將游標(biāo)放到最后一頁開始的位置
IF @Cursor > @Count
BEGIN
-- 如果最后一頁與最大每次紀(jì)錄數(shù)相等,返回最后整頁
IF @Count % @MaxPageSize = 0
BEGIN
IF @Cursor > @MaxPageSize
Set @Cursor = @Count - @MaxPageSize + 1
ELSE
Set @Cursor = 1
END
-- 否則返回最后一頁剩下的紀(jì)錄
ELSE
Set @Cursor = @Count - (@Count % @MaxPageSize) + 1
END
-- 將指針指到該頁開始
Set Rowcount @Cursor
-- 得到紀(jì)錄開始的位置
Select @Name = tag_Name
FROM [viewdatabase0716].[dbo].[view_tag]
orDER BY tag_Name;
-- 設(shè)置開始位置
Set Rowcount @MaxPageSize
-- 得到該頁紀(jì)錄
Select *
From [viewdatabase0716].[dbo].[view_tag]
Where tag_Name >= @Name
order By tag_Name

Set Rowcount 0
END


分頁控件
復(fù)制代碼 代碼如下:

using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;

/// summary>
/// 擴展連接字符串
/// /summary>
public class ExStringBuilder
{
private StringBuilder InsertString;
private StringBuilder PageString;
private int PrivatePageNum = 1;
private int PrivateMaxPageSize = 25;
private int PrivateMaxPages = 10;
private int PrivateCount;
private int PrivateAllPage;
public ExStringBuilder()
{
InsertString = new StringBuilder("");
}
/// summary>
/// 得到生成的HTML
/// /summary>
public string GetHtml
{
get
{
return InsertString.ToString();
}
}
/// summary>
/// 得到生成的分頁HTML
/// /summary>
public string GetPageHtml
{
get
{
return PageString.ToString();
}
}
/// summary>
/// 設(shè)置或獲取目前頁數(shù)
/// /summary>
public int PageNum
{
get
{
return PrivatePageNum;
}
set
{
if (value >= 1)
{
PrivatePageNum = value;
}
}
}
/// summary>
/// 設(shè)置或獲取最大分頁數(shù)
/// /summary>
public int MaxPageSize
{
get
{
return PrivateMaxPageSize;
}
set
{
if (value >= 1)
{
PrivateMaxPageSize = value;
}
}
}
/// summary>
/// 設(shè)置或獲取每次顯示最大頁數(shù)
/// /summary>
public int MaxPages
{
get
{
return PrivateMaxPages;
}
set
{
PrivateMaxPages = value;
}
}
/// summary>
/// 設(shè)置或獲取數(shù)據(jù)總數(shù)
/// /summary>
public int DateCount
{
get
{
return PrivateCount;
}
set
{
PrivateCount = value;
}
}
/// summary>
/// 獲取數(shù)據(jù)總頁數(shù)
/// /summary>
public int AllPage
{
get
{
return PrivateAllPage;
}
}
/// summary>
/// 初始化分頁
/// /summary>
public void Pagination()
{
PageString = new StringBuilder("");
//得到總頁數(shù)
PrivateAllPage = (int)Math.Ceiling((decimal)PrivateCount / (decimal)PrivateMaxPageSize);
//防止上標(biāo)或下標(biāo)越界
if (PrivatePageNum > PrivateAllPage)
{
PrivatePageNum = PrivateAllPage;
}
//滾動游標(biāo)分頁方式
int LeftRange, RightRange, LeftStart, RightEnd;
LeftRange = (PrivateMaxPages + 1) / 2-1;
RightRange = (PrivateMaxPages + 1) / 2;
if (PrivateMaxPages >= PrivateAllPage)
{
LeftStart = 1;
RightEnd = PrivateAllPage;
}
else
{
if (PrivatePageNum = LeftRange)
{
LeftStart = 1;
RightEnd = LeftStart + PrivateMaxPages - 1;
}
else if (PrivateAllPage - PrivatePageNum RightRange)
{
RightEnd = PrivateAllPage;
LeftStart = RightEnd - PrivateMaxPages + 1;
}
else
{
LeftStart = PrivatePageNum - LeftRange;
RightEnd = PrivatePageNum + RightRange;
}
}

//生成頁碼列表統(tǒng)計
PageString.Append(...);

StringBuilder PreviousString = new StringBuilder("");
//如果在第一頁
if (PrivatePageNum > 1)
{
...
}
else
{
...
}
//如果在第一組分頁
if (PrivatePageNum > PrivateMaxPages)
{
...
}
else
{
...
}
PageString.Append(PreviousString);
//生成中間頁
for (int i = LeftStart; i = RightEnd; i++)
{
//為當(dāng)前頁時
if (i == PrivatePageNum)
{
...
}
else
{
...
}
}
StringBuilder LastString = new StringBuilder("");
//如果在最后一頁
if (PrivatePageNum PrivateAllPage)
{
...
}
else
{
...
}
//如果在最后一組
if ((PrivatePageNum + PrivateMaxPages) PrivateAllPage)
{
...
}
else
{
...
}
PageString.Append(LastString);
}
/// summary>
/// 生成Tag分類表格
/// /summary>
public void TagTable(ExDataRow myExDataRow)
{
InsertString.Append(...);
}

調(diào)用方法:
//得到分頁設(shè)置并放入Session
ExRequest myExRequest = new ExRequest();
myExRequest.PageSession("Tag_", new string[] { "page", "size" });
//生成Tag分頁
ExStringBuilder Tag = new ExStringBuilder();
//設(shè)置每次顯示多少條紀(jì)錄
Tag.MaxPageSize = Convert.ToInt32(Session["Tag_size"]);
//設(shè)置最多顯示多少頁碼
Tag.MaxPages = 9;
//設(shè)置當(dāng)前為第幾頁
Tag.PageNum = Convert.ToInt32(Session["Tag_page"]);
string[][] myNamenValue = new string[2][]{
new string[]{"MaxPageSize","PageNum","Count"},
new string[]{Tag.MaxPageSize.ToString(),Tag.PageNum.ToString()}
};
//調(diào)用存儲過程
DataTable myDataTable = mySQL.BatchGetDB("Tag_Page_Name_Select", myNamenValue, "Count");
Tag.DateCount = (int)mySQL.OutputCommand.Parameters["@Count"].Value;
Tag.Pagination();

HeadPage.InnerHtml = FootPage.InnerHtml = Tag.GetPageHtml;

for (int i = 0, j = myDataTable.Rows.Count; i j; i++)
{
Tag.TagTable(new ExDataRow(myDataTable.Rows[i]));
}
TagBox.InnerHtml = Tag.GetHtml;
您可能感興趣的文章:
  • 真正高效的SQLSERVER分頁查詢(多種方案)
  • oracle,mysql,SqlServer三種數(shù)據(jù)庫的分頁查詢的實例
  • sqlserver分頁的兩種寫法分別介紹
  • sqlserver2005使用row_number() over分頁的實現(xiàn)方法
  • sqlserver 三種分頁方式性能比較[圖文]
  • sqlserver 千萬數(shù)量級分頁存儲過程代碼
  • sqlserver 存儲過程分頁(按多條件排序)
  • SQL Server 2012使用Offset/Fetch Next實現(xiàn)分頁數(shù)據(jù)查詢

標(biāo)簽:通化 遼源 鹽城 邢臺 本溪 巴彥淖爾 朔州 宜春

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sqlserver 高性能分頁實現(xiàn)分析》,本文關(guān)鍵詞  sqlserver,高性能,分頁,實現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sqlserver 高性能分頁實現(xiàn)分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于sqlserver 高性能分頁實現(xiàn)分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩男人天堂| 午夜在线影院| 国产成人欧美一区二区三区的| 亚洲爆爽| 国产网站麻豆精品视频| 欧美a级成人淫片免费看| 欧美18性精品| 国产极品白嫩美女在线观看看| 亚洲天堂一区二区三区四区| 91麻豆精品国产高清在线| 日韩一级精品视频在线观看| 精品久久久久久中文| 国产一区免费在线观看| 成人高清视频免费观看| 精品视频在线观看一区二区| 日韩一级黄色大片| 黄视频网站免费看| 亚欧成人毛片一区二区三区四区| 欧美a级片免费看| 亚洲 欧美 成人日韩| 国产a毛片| 在线观看成人网| 欧美大片一区| 成人免费网站久久久| 日韩中文字幕一区二区不卡| 国产成a人片在线观看视频 | 99久久精品国产免费| 国产一区二区精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 高清一级做a爱过程不卡视频| 国产极品白嫩美女在线观看看| 国产a一级| 成人影院久久久久久影院| 成人在免费观看视频国产| 亚久久伊人精品青青草原2020| 一本伊大人香蕉高清在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产精品自拍一区| 国产韩国精品一区二区三区| 成人免费网站久久久| 亚欧成人乱码一区二区| 中文字幕97| 久久国产精品只做精品| 黄色免费三级| 亚欧成人毛片一区二区三区四区| 中文字幕97| 可以在线看黄的网站| 可以免费在线看黄的网站| 九九热精品免费观看| 国产视频网站在线观看| 欧美a免费| 欧美18性精品| 97视频免费在线观看| 麻豆网站在线看| 精品在线观看一区| 中文字幕97| 成人高清视频免费观看| 精品国产一区二区三区久| 日本在线www| 精品美女| 国产亚洲免费观看| 二级片在线观看| 四虎久久精品国产| 日韩av东京社区男人的天堂| 日韩av东京社区男人的天堂| 91麻豆精品国产综合久久久| 精品视频免费看| 天天做人人爱夜夜爽2020毛片| 日本乱中文字幕系列| 91麻豆国产| 午夜在线亚洲男人午在线| 久久精品免视看国产明星| 中文字幕97| 国产一区二区精品久久91| 高清一级淫片a级中文字幕 | 日本免费乱人伦在线观看 | 麻豆午夜视频| 色综合久久天天综合绕观看| 国产视频网站在线观看| 国产伦久视频免费观看视频| 色综合久久手机在线| 精品国产亚一区二区三区| 国产亚洲精品aaa大片| 亚欧成人乱码一区二区| 99色吧| 亚欧视频在线| 国产亚洲精品成人a在线| 精品久久久久久中文字幕2017| 欧美另类videosbestsex视频 | 国产一区免费在线观看| 国产伦精品一区二区三区无广告| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 韩国毛片 免费| 91麻豆精品国产自产在线观看一区 | 午夜欧美成人久久久久久| 黄色短视屏| 深夜做爰性大片中文| 一级毛片视频播放| 一级毛片视频免费| 国产一区免费在线观看| 久久精品免视看国产明星| 免费一级生活片| 韩国毛片免费大片| 亚久久伊人精品青青草原2020| 精品在线视频播放| 九九九国产| 国产麻豆精品hdvideoss| 91麻豆精品国产片在线观看| 一级女性全黄生活片免费| 国产高清视频免费观看| 久久久久久久网| 日本在线不卡视频| 国产美女在线观看| 久久精品欧美一区二区| 久久99爰这里有精品国产| 高清一级淫片a级中文字幕 | 欧美激情影院| 黄视频网站免费看| 国产麻豆精品高清在线播放| 日本免费看视频| 午夜在线影院| 色综合久久天天综合观看| 香蕉视频亚洲一级| 精品视频在线观看视频免费视频 | 久久国产精品自由自在| 国产91精品露脸国语对白| 日本乱中文字幕系列| 国产精品12| 天堂网中文在线| 色综合久久手机在线| 国产高清在线精品一区a| 美女免费精品高清毛片在线视| 二级特黄绝大片免费视频大片| a级精品九九九大片免费看| 美女免费毛片| 日本在线不卡免费视频一区| 你懂的日韩| 黄视频网站在线看| 999久久久免费精品国产牛牛| 国产亚洲精品aaa大片| 午夜欧美福利| 九九九网站| 亚洲第一页色| 国产a免费观看| 亚洲不卡一区二区三区在线| 精品在线观看国产| 国产一区二区精品尤物| 亚飞与亚基在线观看| 四虎影视久久久免费| 欧美一区二区三区性| 国产一区二区福利久久| 日韩av成人| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 青青久热| 99色视频在线观看| 亚飞与亚基在线观看| 日本特黄特色aaa大片免费| 国产网站免费在线观看| 青青久久国产成人免费网站| 国产成人精品一区二区视频| 色综合久久手机在线| 日韩免费片| 九九精品久久久久久久久| 精品视频在线观看视频免费视频 | 麻豆系列 在线视频| 国产精品免费久久| 黄视频网站在线免费观看| 亚洲精品中文字幕久久久久久| 青草国产在线观看| 沈樵在线观看福利| 韩国三级视频网站| 亚欧成人毛片一区二区三区四区| 韩国毛片| a级精品九九九大片免费看| 精品国产亚洲人成在线| 日韩在线观看免费完整版视频| 日本免费区| 国产亚洲精品成人a在线| 国产伦久视频免费观看视频| 日日爽天天| 久久成人性色生活片| 精品视频在线观看免费| 二级特黄绝大片免费视频大片| 香蕉视频亚洲一级| 台湾美女古装一级毛片| 国产综合91天堂亚洲国产| 精品久久久久久影院免费| 精品国产一区二区三区国产馆| 欧美国产日韩在线| 欧美激情伊人| 成人免费网站视频ww| 国产国语对白一级毛片| 一级女性大黄生活片免费| 午夜激情视频在线观看| 国产一区二区精品久久91| 日本免费区| 亚洲精品影院久久久久久| 亚欧成人毛片一区二区三区四区| 久草免费资源| 青青久久精品|