欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

分頁 SQLServer存儲過程

 更新時間:2006年08月24日 00:00:00   作者:  
/*--用存儲過程實現(xiàn)的分頁程序
顯示指定表、視圖、查詢結(jié)果的第X頁
對于表中主鍵或標識列的情況,直接從原表取數(shù)查詢,其它情況使用臨時表的方法
如果視圖或查詢結(jié)果中有主鍵,不推薦此方法
--鄒建 2003.09--*/
/*--調(diào)用示例
exec p_show '地區(qū)資料'
exec p_show '地區(qū)資料',5,3,'地區(qū)編號,地區(qū)名稱,助記碼','地區(qū)編號'
--*/
/*
因為要顧及通用性,所以對帶排序的查詢語句有一定要求.如果先排序,再出結(jié)果.就是:
exec p_show 'select top 100 percent * from 地區(qū)資料 order by 地區(qū)名稱',5,3,'地區(qū)編號,地區(qū)名稱,助記碼','地區(qū)名稱'
--查詢語句加上: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, --每頁的大小(行數(shù))
@PageCurrent int=1, --要顯示的頁
@FdShow nvarchar (4000)='', --要顯示的字段列表,如果查詢結(jié)果有標識字段,需要指定此值,且不包含標識字段
@FdOrder nvarchar (1000)='' --排序字段列表
as
declare @FdName nvarchar(250) --表中的主鍵或表、臨時表中的標識列名
,@Id1 varchar(20),@Id2 varchar(20) --開始和結(jié)束的記錄號
,@Obj_ID int --對象ID
--表中有復(fù)合主鍵的處理
declare @strfd nvarchar(2000) --復(fù)合主鍵列表
,@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 --檢查表中的主鍵是否為復(fù)合主鍵
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
/*--表中有復(fù)合主鍵的處理方法--*/
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

相關(guān)文章

  • 僅用一句SQL更新整張表的漲跌幅、漲跌率的解決方案

    僅用一句SQL更新整張表的漲跌幅、漲跌率的解決方案

    這篇文章主要介紹了僅用一句SQL更新整張表的漲跌幅、漲跌率的解決方案,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • 獲取SQL Server2014的安裝時間

    獲取SQL Server2014的安裝時間

    最近安裝SQL Server 2014時,還沒有正式的License,只能試用3個月。想知道什么時候到期,就要知道SQL Server 2014是什么時候安裝的。
    2014-07-07
  • SQL臨時表遞歸查詢子信息并返回記錄的代碼

    SQL臨時表遞歸查詢子信息并返回記錄的代碼

    SQL臨時表遞歸查詢子信息并返回記錄的代碼,需要的朋友可以參考下
    2012-08-08
  • SQL Server視圖的講解

    SQL Server視圖的講解

    今天小編就為大家分享一篇關(guān)于SQL Server視圖的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解

    SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解

    SQL Server 2012有一個新函數(shù),就是CONCAT函數(shù),連接字符串非它莫屬。比如在它出現(xiàn)之前,連接字符串是使用"+"來連接,如遇上NULL,還得設(shè)置參數(shù)與配置,不然連接出來的結(jié)果將會是一個NULL。本文就介紹了關(guān)于SQL SERVER 2012中CONCAT函數(shù)的相關(guān)資料,需要的朋友可以參考。
    2017-03-03
  • SQL Server FileStream詳解

    SQL Server FileStream詳解

    FILESTREAM是SQL Server 2008中的一個新特性,允許以獨立文件的形式存放大對象數(shù)據(jù),而不是以往一樣將所有數(shù)據(jù)都保存到數(shù)據(jù)文件中
    2015-12-12
  • 使SQL用戶只能看到自己擁有權(quán)限的庫(圖文教程)

    使SQL用戶只能看到自己擁有權(quán)限的庫(圖文教程)

    使SQL用戶只能看到自己擁有權(quán)限的庫,想實現(xiàn)這一點并不難,本文以SQL Server 2012 為例為大家詳細介紹,感興趣的朋友可以參考下
    2012-12-12
  • 調(diào)整SQLServer2000運行中數(shù)據(jù)庫結(jié)構(gòu)

    調(diào)整SQLServer2000運行中數(shù)據(jù)庫結(jié)構(gòu)

    這篇文章主要介紹了調(diào)整SQLServer2000運行中數(shù)據(jù)庫結(jié)構(gòu),十分實用的一個功能,這里推薦給大家,有需要的小伙伴可以參考下。
    2015-04-04
  • MySQL 5.7 create VIEW or FUNCTION or PROCEDURE

    MySQL 5.7 create VIEW or FUNCTION or PROCEDURE

    這篇文章主要介紹了MySQL 5.7 create VIEW or FUNCTION or PROCEDURE的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • SQL Server常見問題及解決方法分享

    SQL Server常見問題及解決方法分享

    這篇文章主要為大家詳細介紹了SQL Server常見問題及解決方法,包括SQL Server連接問題,SQL Server日志問題,SQL Server查詢很久等問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評論