亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

分頁 SQLServer存儲過程

2024-08-31 01:00:29
字體:
來源:轉載
供稿:網友
/*--用存儲過程實現的分頁程序
顯示指定表、視圖、查詢結果的第X頁
對于表中主鍵或標識列的情況,直接從原表取數查詢,其它情況使用臨時表的方法
如果視圖或查詢結果中有主鍵,不推薦此方法
--鄒建 2003.09--*/
/*--調用示例
exec p_show '地區資料'
exec p_show '地區資料',5,3,'地區編號,地區名稱,助記碼','地區編號'
--*/
/*
因為要顧及通用性,所以對帶排序的查詢語句有一定要求.如果先排序,再出結果.就是:
exec p_show 'select top 100 percent * from 地區資料 order by 地區名稱',5,3,'地區編號,地區名稱,助記碼','地區名稱'
--查詢語句加上:top 100 percent //top時
*/
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_show]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_show]
GO
Create Proc p_show
@QueryStr nvarchar(4000), --表名、視圖名、查詢語句
@PageSize int=10, --每頁的大小(行數)
@PageCurrent int=1, --要顯示的頁
@FdShow nvarchar (4000)='', --要顯示的字段列表,如果查詢結果有標識字段,需要指定此值,且不包含標識字段
@FdOrder nvarchar (1000)='' --排序字段列表
as
declare @FdName nvarchar(250) --表中的主鍵或表、臨時表中的標識列名
,@Id1 varchar(20),@Id2 varchar(20) --開始和結束的記錄號
,@Obj_ID int --對象ID
--表中有復合主鍵的處理
declare @strfd nvarchar(2000) --復合主鍵列表
,@strjoin nvarchar(4000) --連接字段
,@strwhere nvarchar(2000) --查詢條件

select @Obj_ID=object_id(@QueryStr)
,@FdShow=case isnull(@FdShow,'') when '' then ' *' else ' '+@FdShow end
,@FdOrder=case isnull(@FdOrder,'') when '' then '' else ' order by '+@FdOrder end
,@QueryStr=case when @Obj_ID is not null then ' '+@QueryStr else ' ('+@QueryStr+') a' end
--如果顯示第一頁,可以直接用top來完成
if @PageCurrent=1 
begin
select @Id1=cast(@PageSize as varchar(20))
exec('select top '+@Id1+@FdShow+' from '+@QueryStr+@FdOrder)
return
end
--如果是表,則檢查表中是否有標識更或主鍵
if @Obj_ID is not null and objectproperty(@Obj_ID,'IsTable')=1
begin
select @Id1=cast(@PageSize as varchar(20))
,@Id2=cast((@PageCurrent-1)*@PageSize as varchar(20))
select @FdName=name from syscolumns where id=@Obj_ID and status=0x80
if @@rowcount=0 --如果表中無標識列,則檢查表中是否有主鍵
begin
if not exists(select 1 from sysobjects where parent_obj=@Obj_ID and xtype='PK')
goto lbusetemp --如果表中無主鍵,則用臨時表處理
select @FdName=name from syscolumns where id=@Obj_ID and colid in(
select colid from sysindexkeys where @Obj_ID=id and indid in(
select indid from sysindexes where @Obj_ID=id and name in(
select name from sysobjects where xtype='PK' and parent_obj=@Obj_ID
)))
if @@rowcount>1 --檢查表中的主鍵是否為復合主鍵
begin
select @strfd='',@strjoin='',@strwhere=''
select @strfd=@strfd+',['+name+']'
,@strjoin=@strjoin+' and a.['+name+']=b.['+name+']'
,@strwhere=@strwhere+' and b.['+name+'] is null'
from syscolumns where id=@Obj_ID and colid in(
select colid from sysindexkeys where @Obj_ID=id and indid in(
select indid from sysindexes where @Obj_ID=id and name in(
select name from sysobjects where xtype='PK' and parent_obj=@Obj_ID
)))
select @strfd=substring(@strfd,2,2000)
,@strjoin=substring(@strjoin,5,4000)
,@strwhere=substring(@strwhere,5,4000)
goto lbusepk
end
end
end
else
goto lbusetemp
/*--使用標識列或主鍵為單一字段的處理方法--*/
lbuseidentity: 
exec('select top '+@Id1+@FdShow+' from '+@QueryStr
+' where '+@FdName+' not in(select top '
+@Id2+' '+@FdName+' from '+@QueryStr+@FdOrder
+')'+@FdOrder
)
return
/*--表中有復合主鍵的處理方法--*/
lbusepk: 
exec('select '+@FdShow+' from(select top '+@Id1+' a.* from
(select top 100 percent * from '+@QueryStr+@FdOrder+') a
left join (select top '+@Id2+' '+@strfd+' 
from '+@QueryStr+@FdOrder+') b on '+@strjoin+'
where '+@strwhere+') a'
)
return
/*--用臨時表處理的方法--*/
lbusetemp: 
select @FdName='[ID_'+cast(newid() as varchar(40))+']'
,@Id1=cast(@PageSize*(@PageCurrent-1) as varchar(20))
,@Id2=cast(@PageSize*@PageCurrent-1 as varchar(20))
exec('select '+@FdName+'=identity(int,0,1),'+@FdShow+'
into #tb from'+@QueryStr+@FdOrder+'
select '+@FdShow+' from #tb where '+@FdName+' between '
+@Id1+' and '+@Id2
)
GO
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕日韩在线观看| 日韩视频免费大全中文字幕| 91精品视频在线播放| 久久久久久香蕉网| 欧美一级黄色网| 亚洲国语精品自产拍在线观看| 日本欧美爱爱爱| 国产一区二区三区在线观看视频| 91精品国产高清自在线看超| 伊人成人开心激情综合网| 亚洲国产成人精品久久| 成人久久精品视频| 亚洲无av在线中文字幕| 精品久久香蕉国产线看观看gif| 亚洲精品免费在线视频| www.久久撸.com| 青青久久av北条麻妃黑人| 欧美午夜视频在线观看| 国产精品白嫩美女在线观看| 91精品在线观看视频| 日韩高清电影好看的电视剧电影| 久久久久久久久91| 亚洲国产日韩一区| 久久国产精品免费视频| 国产精品普通话| 不卡av电影院| 国产精品极品美女粉嫩高清在线| 欧美午夜激情在线| 国产成人免费av电影| 海角国产乱辈乱精品视频| 欧美精品日韩www.p站| 亚洲电影中文字幕| 日韩美女在线观看一区| 91嫩草在线视频| 在线成人免费网站| 国产欧美一区二区三区四区| 精品视频在线观看日韩| 欧美成人中文字幕在线| 国产亚洲视频在线观看| 日本国产精品视频| 欧美美最猛性xxxxxx| 国产精品福利在线观看网址| 一区二区三区日韩在线| 日韩av成人在线| 亚洲视频欧美视频| 国产欧美久久久久久| 精品中文字幕久久久久久| 亚洲第一网中文字幕| 另类美女黄大片| 78色国产精品| 91午夜理伦私人影院| 久久精品国产欧美激情| 亚洲精品aⅴ中文字幕乱码| 日韩激情视频在线播放| 久久久久久国产免费| 日韩电影中文 亚洲精品乱码| 成人精品福利视频| 黄网动漫久久久| 久久亚洲成人精品| 日韩欧美在线视频日韩欧美在线视频| 97色在线播放视频| 成人精品视频99在线观看免费| 日韩在线视频观看正片免费网站| 国产视频丨精品|在线观看| www.国产精品一二区| 亚洲一区二区在线播放| 亚洲999一在线观看www| 国语自产精品视频在免费| 亚洲一区二区精品| 欧美精品成人在线| 亚洲精品一区二区久| 欧美激情在线观看视频| 成人久久精品视频| 欧美另类99xxxxx| 国产日韩欧美成人| www.日韩系列| 在线亚洲午夜片av大片| 日本高清久久天堂| 米奇精品一区二区三区在线观看| 亚洲天堂免费在线| 精品久久久久久电影| 亚洲精品一区久久久久久| 亚洲电影免费观看高清完整版在线观看| 国产v综合ⅴ日韩v欧美大片| 自拍亚洲一区欧美另类| 久久国内精品一国内精品| 国产精品激情av在线播放| 午夜精品理论片| 一区二区三区www| 国产视频精品久久久| 国产精品三级久久久久久电影| 国内精品视频久久| 成人高清视频观看www| 亚洲美女性视频| 国产精品999999| 欧美激情一级二级| 秋霞av国产精品一区| 日韩网站在线观看| 亚洲一区二区久久久久久久| 91久久嫩草影院一区二区| 成人黄色免费看| 狠狠色噜噜狠狠狠狠97| 尤物tv国产一区| 亚洲成人网av| 欧美一区二区三区四区在线| 韩国视频理论视频久久| 国产欧美一区二区| 亚洲欧美制服另类日韩| 国产精品第七影院| 久久久久久美女| 91av视频导航| 国产精品欧美风情| 日韩激情片免费| 在线观看国产精品91| 成人免费在线视频网站| 色婷婷综合久久久久中文字幕1| 国产成人精品999| 国产91色在线播放| 91精品久久久久久| 国内久久久精品| 亚洲第一区中文99精品| 91超碰中文字幕久久精品| 国产日韩一区在线| 欧美亚洲成人精品| 国产精品久久久久av| 岛国av一区二区三区| 欧美日韩亚洲天堂| 日韩国产精品亚洲а∨天堂免| 国产欧美婷婷中文| 国产精品海角社区在线观看| 久久久亚洲福利精品午夜| 91精品综合久久久久久五月天| 国产欧美一区二区三区四区| 日韩美女视频免费在线观看| 欧美日韩国产限制| 97人人爽人人喊人人模波多| 日韩经典第一页| 日韩欧美黄色动漫| 欧美成年人网站| 国产亚洲欧美日韩精品| 中文字幕成人在线| 性欧美xxxx交| 51精品国产黑色丝袜高跟鞋| 亚洲天堂男人天堂女人天堂| 欧美激情三级免费| 国产精品成人一区二区| 91伊人影院在线播放| 亚洲品质视频自拍网| 国产精品一区二区三区成人| 亚洲国产精品女人久久久| 亚洲欧美视频在线| 成人福利免费观看| 中日韩美女免费视频网站在线观看| 欧美剧在线观看| 在线观看免费高清视频97| 亚洲视频欧美视频| 最新国产精品亚洲| 综合136福利视频在线| 国产精品久久二区| 亚洲天堂久久av| 亚洲欧洲一区二区三区久久| 91在线中文字幕| 亚洲欧美日韩图片| 亚洲欧美日本精品|