海量資料庫的查詢優化及分頁演算法方案

2021-04-08 19:11:52 字數 2408 閱讀 3312

create procedure pagination3

@tblname   varchar(255),       -- 表名

@strgetfields varchar(1000) = '*',  -- 需要返回的列

@fldname varchar(255)='',      -- 排序的欄位名

@pagesize   int = 10,          -- 頁尺寸

@pageindex  int = 1,           -- 頁碼

@docount  bit = 0,   -- 返回記錄總數, 非 0 值則返回

@ordertype bit = 0,  -- 設定排序型別, 非 0 值則降序

@strwhere  varchar(1500) = ''  -- 查詢條件 (注意: 不要加 where)

asdeclare @strsql   varchar(5000)       -- 主語句

declare @strtmp   varchar(110)        -- 臨時變數

declare @strorder varchar(400)        -- 排序型別

if @docount != 0

begin

if @strwhere !=''

set @strsql = 'select count(*) as total from [' + @tblname + '] where '+@strwhere

else

set @strsql = 'select count(*) as total from [' + @tblname + ']'

end 

--以上**的意思是如果@docount傳遞過來的不是0,就執行總數統計。以下的所有**都是@docount為0的情況

else

begin

if @ordertype != 0

begin

set @strtmp = '<(select min'

set @strorder = ' order by [' + @fldname +'] desc'

--如果@ordertype不是0,就執行降序,這句很重要!

endelse

begin

set @strtmp = '>(select max'

set @strorder = ' order by [' + @fldname +'] asc'

endif @pageindex = 1

begin

if @strwhere != ''  

set @strsql = 'select top ' + str(@pagesize) +' '+@strgetfields+ '  from [' + @tblname + '] where ' + @strwhere + ' ' + @strorder

else

set @strsql = 'select top ' + str(@pagesize) +' '+@strgetfields+ '  from ['+ @tblname + '] '+ @strorder

--如果是第一頁就執行以上**,這樣會加快執行速度

endelse

begin

--以下**賦予了@strsql以真正執行的sql**

set @strsql = 'select top ' + str(@pagesize) +' '+@strgetfields+ '  from ['

+ @tblname + '] where [' + @fldname + ']' + @strtmp + '(['+ @fldname + ']) from (select top ' + str((@pageindex-1)*@pagesize) + ' ['+ @fldname + '] from [' + @tblname + ']' + @strorder + ') as tbltmp)'+ @strorder

if @strwhere != ''

set @strsql = 'select top ' + str(@pagesize) +' '+@strgetfields+ '  from ['

+ @tblname + '] where [' + @fldname + ']' + @strtmp + '(['

+ @fldname + ']) from (select top ' + str((@pageindex-1)*@pagesize) + ' ['

+ @fldname + '] from [' + @tblname + '] where ' + @strwhere + ' '

+ @strorder + ') as tbltmp) and ' + @strwhere + ' ' + @strorder

end

end  

exec (@strsql)

go

海量資料庫的查詢優化及分頁演算法方案

如何在有著 1000 萬條資料的 ms sql server 資料庫中實現快速的資料提取和資料分頁。以下 說明了我們例項中資料庫的 紅標頭檔案 一表的部分資料結構 create table dbo tgongwen tgongwen 是紅標頭檔案表名 gid int identity 1,1 not...

資料庫概論 (六)查詢及優化

執行查詢語句之前需要執行一些查詢檢查任務,提高 的健壯性。安全性檢查,檢查執行查詢的使用者許可權是否滿足執行查詢的要求 完整性初步檢查,檢查所要查詢的條件是否滿足資料的型別要求。檢查完成之後會將資料庫語句轉換為對應的語法樹。選擇操作的實現演算法 選擇操作有多種實現方式,例如全表掃描法,索引法,雜湊法...

海量資料處理專題(七) 資料庫索引及優化

索引是對資料庫表中一列或多列的值進行排序的一種結構,使用索引可快速訪問資料庫表中的特定資訊。什麼是索引 資料庫索引好比是一本書前面的目錄,能加快資料庫的查詢速度。例如這樣一個查詢 select from table1 where id 44。如果沒有索引,必須遍歷整個表,直到id等於44的這一行被找...

海量資料處理專題(七) 資料庫索引及優化

索引是對資料庫表中一列或多列的值進行排序的一種結構,使用索引可快速訪問資料庫表中的特定資訊。資料庫索引好比是一本書前面的目錄,能加快資料庫的查詢速度。例如這樣一個查詢 select from table1 where id 44。如果沒有索引,必須遍歷整個表,直到id等於44的這一行被找到為止 有了...

資料庫連線池及查詢優化

伺服器可以快速建立和斷開連線,但對於高併發的後臺伺服器而言,連線的頻繁建立與斷開,是非常重的負擔。在客戶端與服務端之間可以事先建立若干連線並提前放置在連線池中,需要時可以從連線池直接獲取,資料傳輸完成後,將連線歸還至連線池中,從而減少頻繁建立和釋放連線所造成的開銷。連線資源在資料庫端是一種非常關鍵且...