sql 存储过程分页

USE [as_services]
GO
/****** Object:  StoredProcedure [dbo].[Sp_CustomPageV5]    Script Date: 01/05/2015 09:20:39 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER PROCEDURE [dbo].[Sp_CustomPage]
@QueryStr nvarchar(4000), --表名、视图名、查询语句
@QueryWhere varchar(8000), --查询条件
@PageSize int=10, --每页的大小(行数)
@PageCurrent int=1, --要显示的页
@FdShow nvarchar (4000)=‘‘, --要显示的字段列表,如果查询结果有标识字段,需要指定此值,且不包含标识字段
@FdOrder nvarchar (1000)=‘‘, --排序字段列表
@FdKey nvarchar(250)=‘‘, --强制指定主键
@TotalRow int output --总记录行数
as
declare @FdName nvarchar(250) --表中的主键或表、临时表中的标识列名
,@Id1 varchar(20),@Id2 varchar(20) --开始和结束的记录号
,@Id3 varchar(20) --预选的记录数
,@Obj_ID int --对象ID
,@TotalPage int --总页数
,@FdOrder_desc nvarchar(1000)  --‘反‘排序字段列表
,@FdOrder_desc1 nvarchar(1000) --‘反‘排序字段列表
,@FdOrder_desc2 nvarchar(1000) --‘反‘排序字段列表
--表中有复合主键的处理
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
,@QueryWhere=case isnull(@QueryWhere,‘‘) when ‘‘ then ‘1=1‘ else @QueryWhere end

select @FdOrder_desc1 = replace(@FdOrder, ‘ DESC‘, ‘^‘)
,@FdOrder_desc2 = replace(@FdOrder_desc1, ‘,‘, ‘ DESC,‘) + ‘ DESC‘
,@FdOrder_desc = replace(@FdOrder_desc2, ‘^ DESC‘, ‘‘)
,@FdOrder_desc = replace(@FdOrder_desc, ‘ asc DESC‘, ‘ DESC‘)
select @FdOrder = replace(@FdOrder, ‘^^‘, ‘,‘)
,@FdOrder_desc = replace(@FdOrder_desc, ‘^^‘, ‘,‘)

if left(@QueryStr,1)=‘(‘
  select @QueryStr=‘ ‘+@QueryStr
else
  select @QueryStr=case when @Obj_ID is not null then ‘ ‘+@QueryStr else ‘ (‘+@QueryStr+‘) cp_a‘ end
--计算总行数和总页数
declare @temp1 nvarchar(4000)
select @temp1=N‘select @temp2=count(*) from ‘+@QueryStr+‘ where ‘+@QueryWhere
exec sp_executesql @temp1, N‘ @temp2 int output ‘, @TotalRow output
if @TotalRow > 0
  set @TotalPage = (@TotalRow + @PageSize - 1) / @PageSize
else
  set @TotalPage = 1
if @PageCurrent > @TotalPage set @PageCurrent = @TotalPage
--如果显示第一页,可以直接用top来完成
if @PageCurrent=1
begin
  select @Id1=cast(@PageSize as varchar(20))
  exec(‘select top ‘+@Id1+@FdShow+‘ from ‘+@QueryStr+‘ where ‘+@QueryWhere+@FdOrder)
  return
end
--强制指定主键
if @FdKey<>‘‘
begin
  select @Id1=cast(@PageSize as varchar(20))
  ,@Id2=cast((@PageCurrent-1)*@PageSize as varchar(20))
  ,@Id3=cast(@PageCurrent*@PageSize as varchar(20))
  select @FdName=@FdKey
  goto lbuseidentity
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))
  ,@Id3=cast(@PageCurrent*@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:
if (@PageCurrent >= @TotalPage) and (@TotalRow % @PageSize > 0)
  select @Id1 = @TotalRow % @PageSize
exec(‘select * from
(select top ‘+@Id1+@FdShow+‘ from ‘+@QueryStr+‘ where ‘+@FdName+‘ in (
  select top ‘+@Id3+‘ ‘+@FdName+‘ from ‘+@QueryStr+‘ where ‘+@QueryWhere+@FdOrder
  +‘)‘+@FdOrder_desc
+‘) cp_v5‘ + @FdOrder
)
return
/*--表中有复合主键的处理方法--*/
lbusepk:
exec(‘select ‘+@FdShow+‘ from(select top ‘+@Id1+‘ a.* from
(select top 100 percent * from ‘+@QueryStr+‘ where ‘+@QueryWhere+@FdOrder+‘) a
left join (select top ‘+@Id2+‘ ‘+@strfd+‘
from ‘+@QueryStr+‘ where ‘+@QueryWhere+@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))
,@Id3=cast(@PageSize*@PageCurrent as varchar(20))
exec(‘select ‘+@FdName+‘=identity(int,0,1),*
into #tb from (select top ‘+@Id3+‘ ‘+@FdShow+‘ from ‘+@QueryStr+‘ where ‘+@QueryWhere+@FdOrder+‘) cp_tb
select ‘+@FdShow+‘ from #tb where ‘+@FdName+‘ between ‘
+@Id1+‘ and ‘+@Id2
)
ALTER PROCEDURE [dbo].[get_list]
@QueryStr nvarchar(4000), --表名、视图名、查询语句
@QueryWhere varchar(8000), --查询条件
@FdShow nvarchar (4000)=‘*‘, --要显示的字段列表,如果查询结果有标识字段,需要指定此值,且不包含标识字段
@FdOrder nvarchar (1000)=‘‘ --排序字段列表
as

declare @sqlQuery nvarchar(4000)

set @sqlQuery=‘select ‘+@FdShow +‘ from ‘+@QueryStr +‘ where ‘+ @QueryWhere +‘ order by ‘+@FdOrder
print @sqlQuery

exec sp_executesql @sqlQuery
SqlCommand cmd = dbHelper.GetStoredProcCommond("Sp_CustomPage");
            dbHelper.AddInParameter(cmd, "@QueryStr", System.Data.DbType.String, sTable);
            dbHelper.AddInParameter(cmd, "@QueryWhere", System.Data.DbType.String, sWhere);
            dbHelper.AddInParameter(cmd, "@PageSize", System.Data.DbType.Int32, iPageSize);
            dbHelper.AddInParameter(cmd, "@PageCurrent", System.Data.DbType.Int32, iPageIndex);
            dbHelper.AddInParameter(cmd, "@FdShow", System.Data.DbType.String, sShow);
            dbHelper.AddInParameter(cmd, "@FdOrder", System.Data.DbType.String, sOrder);
            dbHelper.AddInParameter(cmd, "@FdKey", System.Data.DbType.String, sKey);
            dbHelper.AddOutParameter(cmd, "@TotalRow", System.Data.DbType.Int32, 2147483647);

            System.Data.DataTable objTable = new System.Data.DataTable("dataInfo");
            using (DbDataReader reader = dbHelper.ExecuteReader(cmd))
            {
                objTable.Load(reader);
            }

            iRowNum = Convert.ToInt32(cmd.Parameters["@TotalRow"].Value.ToString());
            iPageNum = (iRowNum + iPageSize - 1) / iPageSize;
时间: 2024-09-29 02:54:51

sql 存储过程分页的相关文章

SQL 存储过程 分页

set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ============================================= -- Author: *** -- Create date: 2014-03-27 20:00 -- Description: 采用最新的 row_number() over 技术高效分页方法 -- ============================================= ALTER PRO

SQL存储过程分页(通用的拼接SQL语句思路实现)

多表通用的SQL存储过程分页 USE [EmailCenter] GO /****** Object: StoredProcedure [dbo].[Common_PageList] Script Date: 2016/2/29 11:00:19 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROC [dbo].[Common_PageList] ( @tab nvarchar(200),---表名 @strFl

SQL存储过程分页查询--只支持MSSQL2005及以上

USE [QSM] GO /****** Object: StoredProcedure [dbo].[UP_SysGetListByPage] Script Date: 04/12/2017 17:47:02 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Author: <Author,,Name> -- Create d

SQL 存储过程 分页查询

ALTER PROCEDURE [dbo].[gzProc_TablePage] @tablename varchar(MAX),--表名 @selcolumn varchar(MAX),--查询字段 @where varchar(MAX),--where条件 @sortcolumn varchar(MAX),--排序字段 @pagecount int,--每页记录数 @pageindex int--页号ASBEGIN /*************************************

SQL存储过程分页

CREATE PROC ZDY_FY(@Pages INT, @pageRow INT) --@Pages第几页 @pageRow每页显示几行 AS BEGIN DECLARE @starNum INT, --开始行 @endNum INT --结束行 SET @starNum = (@Pages -1) * @pageRow SET @endNum = @starNum + @pageRow SELECT * FROM ( SELECT ROW_NUMBER() OVER(ORDER BY D

sql 高性能存储过程分页

USE [Lyjjr] GO /****** Object: StoredProcedure [dbo].[P_ViewPage] Script Date: 05/29/2015 17:18:56 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER PROC [dbo].[P_ViewPage] @TableName VARCHAR(200), --表名 @FieldList VARCHAR(2000), --显示列名,如

创建sql自定义的函数及商品分页sql存储过程

--商品筛选时判断品牌ID是否存在 --select dbo.isValite(94,94)create function isValite(@brandId int,@bId int)returns intas begin Declare @rNumber int if @brandId = @bId set @rNumber = 1 else set @rNumber = 0 if @bId = 0 set @rNumber = 1 return @rNumberendgo --判断商品筛选

sql server存储过程分页,行变列

CREATE PROCEDURE [dbo].[PROC_GetPriviousAndNextDetailContent]@Index varchar(20),--表主键@Table varchar(100),--从哪个表获取数据@Columns varchar(100),--需要获取哪些字段@OrderStr varchar(100),--排序字段及方式@Where1    varchar(100),--row_number中的初步过滤条件@Where2 varchar(100)--当前要查询

Oracle ——存储过程——分页

输入:表名.每页显示的记录数.当前页输出:总记录数.总页数.结果集--首先,创建一个包,定义游标类型CREATE OR REPLACE PACKAGE fenye_package ISTYPE fenye_cursor IS REF CURSOR;END fenye_package; --输入:表名.每页显示的记录数.当前页--输出:总记录数.总页数.结果集CREATE OR REPLACE PROCEDURE sp_fenye(tableName   IN VARCHAR2,--表名称 max