分页存储过程[转载]

SQL2000CREATE PROCEDURE [dbo].[ProcCustomPage]
    (
     @Table_Name varchar(5000),    --表名
     @Sign_Record varchar(50),     --主键
     @Filter_Condition varchar(1000),    --筛选条件,不带where
     @Page_Size int,     --页大小
     @Page_Index int,       --页索引
   @TaxisField varchar(1000), --排序字段
     @Taxis_Sign int,     --排序方式 1为 DESC, 0为 ASC
@Find_RecordList varchar(1000),   --查找的字段
     @Record_Count int     --总记录数
     )
     AS
      BEGIN
      DECLARE @Start_Number int
      DECLARE @End_Number int
      DECLARE @TopN_Number int
     DECLARE @sSQL varchar(8000)
if(@Find_RecordList=‘‘)
BEGIN
SELECT @Find_RecordList=‘*‘
END
     SELECT @Start_Number =(@Page_Index-1) * @Page_Size
      IF @Start_Number<=0
     SElECT @Start_Number=0
      SELECT @End_Number=@Start_Number+@Page_Size
      IF @End_Number>@Record_Count
     SELECT @End_Number=@Record_Count
     SELECT @TopN_Number=@End_Number-@Start_Number
     IF @TopN_Number<=0
     SELECT @TopN_Number=0
      print @TopN_Number
     print @Start_Number
     print @End_Number
     print @Record_Count
IF @TaxisField=‘‘
begin
select @TaxisField=@Sign_Record
end
     IF @Taxis_Sign=0
       BEGIN
         IF @Filter_Condition=‘‘
         BEGIN
           SELECT @sSQL=‘SELECT ‘+@Find_RecordList+‘ FROM ‘+@Table_Name+‘
           WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@TopN_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
            WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@End_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
          ORDER BY ‘+@TaxisField+‘) order by ‘+@TaxisField+‘ DESC)order by ‘+@TaxisField
         END
        ELSE
        BEGIN
        SELECT @sSQL=‘SELECT ‘+@Find_RecordList+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@TopN_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@End_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Filter_Condition+‘ ORDER BY ‘+@TaxisField+‘) and ‘+@Filter_Condition+‘ order by ‘+@TaxisField+‘ DESC) and ‘+@Filter_Condition+‘ order by ‘+@TaxisField
         END
      END
    ELSE
      BEGIN
      IF @Filter_Condition=‘‘
        BEGIN
          SELECT @sSQL=‘SELECT ‘+@Find_RecordList+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@TopN_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@End_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     ORDER BY ‘+@TaxisField+‘ DESC) order by ‘+@TaxisField+‘)order by ‘+@TaxisField+‘ DESC‘
     END
      ELSE
      BEGIN
        SELECT @sSQL=‘SELECT ‘+@Find_RecordList+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@TopN_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Sign_Record+‘ in (SELECT TOP ‘+CAST(@End_Number AS VARCHAR(10))+‘ ‘+@Sign_Record+‘ FROM ‘+@Table_Name+‘
     WHERE ‘+@Filter_Condition+‘ ORDER BY ‘+@TaxisField+‘ DESC) and ‘+@Filter_Condition+‘ order by ‘+@TaxisField+‘) and ‘+@Filter_Condition+‘ order by ‘+@TaxisField+‘ DESC‘
     END
      END
      EXEC (@sSQL)
      IF @@ERROR<>0
      RETURN -3
     RETURN 0
     END

     PRINT @sSQL
GO

2005

CREATE PROCEDURE [dbo].[GetRecordFromPage]
@SelectList VARCHAR(2000), --欲选择字段列表
@TableSource VARCHAR(100), --表名或视图表
@SearchCondition VARCHAR(2000), --查询条件
@OrderExpression VARCHAR(1000), --排序表达式
@PageIndex INT = 1, --页号,从0开始
@PageSize INT = 10 --页尺寸
AS
BEGIN
IF @SelectList IS NULL OR LTRIM(RTRIM(@SelectList)) = ‘‘
BEGIN
SET @SelectList = ‘*‘
END
PRINT @SelectList

SET @SearchCondition = ISNULL(@SearchCondition,‘‘)
SET @SearchCondition = LTRIM(RTRIM(@SearchCondition))
IF @SearchCondition <> ‘‘
BEGIN
IF UPPER(SUBSTRING(@SearchCondition,1,5)) <> ‘WHERE‘
BEGIN
SET @SearchCondition = ‘WHERE ‘ + @SearchCondition
END
END
PRINT @SearchCondition

SET @OrderExpression = ISNULL(@OrderExpression,‘‘)
SET @OrderExpression = LTRIM(RTRIM(@OrderExpression))
IF @OrderExpression <> ‘‘
BEGIN
IF UPPER(SUBSTRING(@OrderExpression,1,5)) <> ‘WHERE‘
BEGIN
SET @OrderExpression = ‘ORDER BY ‘ + @OrderExpression
END
END
PRINT @OrderExpression

IF @PageIndex IS NULL OR @PageIndex < 1
BEGIN
SET @PageIndex = 1
END
PRINT @PageIndex
IF @PageSize IS NULL OR @PageSize < 1
BEGIN
SET @PageSize = 10
END
PRINT @PageSize

DECLARE @SqlQuery VARCHAR(4000)

SET @SqlQuery=‘SELECT ‘+@SelectList+‘,RowNumber
FROM
(SELECT ‘ + @SelectList + ‘,ROW_NUMBER() OVER( ‘+ @OrderExpression +‘) AS RowNumber
FROM ‘+@TableSource+‘ ‘+ @SearchCondition +‘) AS RowNumberTableSource
WHERE RowNumber BETWEEN ‘ + CAST(((@PageIndex - 1)* @PageSize+1) AS VARCHAR)
+ ‘ AND ‘ +
CAST((@PageIndex * @PageSize) AS VARCHAR)
-- ORDER BY ‘ + @OrderExpression
PRINT @SqlQuery
SET NOCOUNT ON
EXECUTE(@SqlQuery)
SET NOCOUNT OFF

RETURN @@RowCount
END
时间: 2024-11-09 05:51:30

分页存储过程[转载]的相关文章

毫秒级百万数据分页存储过程[欢迎转载]

数据分页一直是一个经久不衰的话题,在园子里看到了N多高手,都比我厉害, 今天把我使用的分页代码继续分享;请高手手下留情,少拍砖啦...哈哈; 欢迎大家转载!!!! 首先参考园子里的高手方法生成一个百万数据表; 耗时 33 秒; 然后创建分页存储过程;这个是基于SQL 2005 的ROW_NUMBER的, SQL 2000 不适用; SQL 2008 我没有安装,所以也没有测试过!估计应该可以运行. 2种算法可以选择 1. 使用  BETWEEN   ;  2.  TOP  ; 代码中已经注释了.

SQL Server 存储过程(转载)

SQL Server 存储过程 Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这样就可以提高存储过程的性能. Ø 存储过程的概念 存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行. 存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数.输出参数.返回单个或多个结果集以及返回值. 由于存储

sql 可按任意字段排序的分页存储过程

最近做一个项目,其中有许多部分需要用到分页功能 并且这些需要分页的地方有一个共同的特点,那就是,分页,但并不是按ID(主键)来排序,而是要求按其他有重复值的列进行排序,比如,其中有一个页面,要列出将近1万条客户记录,要求按客户付费金额进行排序,这种情况,如果使用网上流行的通用分页存储过程是行不能的,比如,像下面的分页存储过程虽然很棒,可是,用在这里的话,就无计可施:(这个存储过程是我在CSDN上看到一位前辈高人写的) CREATE PROCEDURE GetRecordFromPage @tbl

SQL分页2(转载)

SQL的几种分页算法[转载] (2005-12-19 20:28:52) 转载▼   分类: 技术 1.“俄罗斯存储过程”的改良版CREATE procedure pagination1(@pagesize int,  --页面大小,如每页存储20条记录@pageindex int   --当前页码)asset nocount onbegindeclare @indextable table(id int identity(1,1),nid int)  --定义表变量declare @PageL

SQL基础分页存储过程(案例一)

1 --分页 存储过程 案例 2 3 -- 所执行的存储过程 4 create proc pageForUsers 5 @currPage int, --当前页数 6 @pageSize int, --每页多少条记录 7 @count int output --总记录数 8 as 9 declare @firstIndex int 10 declare @lastIndex int 11 declare @sqlText varchar(200) 12 13 --统计总记录数 14 select

多表查询分页存储过程,解决了第二页不显示的问题

SET ANSI_NULLS OFFGOSET QUOTED_IDENTIFIER OFFGO ALTER PROCEDURE [dbo].[UP_Pagination]/****************************************************************** 千万数量级分页存储过程 *****************************************************************参数说明:1.Tables :表名称,视

oracle分页存储过程

oracle分页存储过程: CREATE OR REPLACE PROCEDURE FGK.prc_page (p_tableName in varchar2, --表名 p_strWhere in varchar2, --查询条件 p_orderColumn in varchar2, --排序的列 p_orderStyle in varchar2, --排序方式 p_curPage in out Number, --当前页 p_pageSize in out Number, --每页显示记录条

sql笔记/分页存储过程

[email protected]c#中进行++操作可以是整数或小数,sql中只能对整数进行++操作.char类型 适合存储长度波动较小不回收效率高varchar 类型 适合存储长度波动较大可以回收nchar代表unicode 存储内容包括汉字时候考虑加n SQL语句特点1不区分大小写2没有双引号所有字符串都包含在单引号3没有逻辑相等,逻辑相等和赋值一样都是用=4没有bool值得概念,但是在视图中可以输入true/false5也有关系运算符.6也有逻辑运算符 &&-- and || --o

sql server分页存储过程

/********************************************************************************* * Function: PagedProc                                                  * * Description: * * Sql2005分页存储过程                                              * * Finish DateT