三种SQL分页查询的存储过程

--根据MAX(MIN)ID
CREATE PROC [dbo].[proc_select_id]
@pageindex int =1, --当前页数
@pagesize int =10, --每页大小
@tablename VARCHAR (50)= '' , --表名
@fields VARCHAR (1000)= '' , --查询的字段集合
@keyid VARCHAR (50)= '' , --主键
@condition NVARCHAR(1000)= '' , --查询条件
@orderstr VARCHAR (500), --排序条件
@totalRecord BIGINT OUTPUT --总记录数
AS
    IF ISNULL (@orderstr,N '' )=N '' SET @orderstr=N ' ORDER BY ' +@keyid+N ' DESC '
    IF ISNULL (@fields,N '' )=N '' SET @fields=N '*'
    IF ISNULL (@condition,N '' )=N '' SET @condition=N '1=1'
    DECLARE @sql NVARCHAR(4000)
    --IF(@totalRecord IS NULL)
    --BEGIN
        SET @sql=N 'SELECT @totalRecord=COUNT(*)'
            +N ' FROM ' +@tablename
            +N ' WHERE ' +@condition
        EXEC sp_executesql @sql,N '@totalRecord INT OUTPUT' ,@totalRecord OUTPUT
    --END
    IF(@pageindex=1)
    BEGIN
        SET @sql=N 'SELECT TOP ' +STR(@pagesize)+N ' ' +@fields+N ' FROM ' +@tablename+N ' WHERE ' +@condition+N ' ' +@orderstr
        EXEC (@sql)
    END
    ELSE
    BEGIN
        DECLARE @operatestr CHAR (3),@comparestr CHAR (1)
        SET @operatestr= 'MAX'
        SET @comparestr= '>'
        IF(@orderstr<> '' )
        BEGIN
            IF(CHARINDEX( 'desc' , LOWER (@orderstr))<>0)
            BEGIN
                SET @operatestr= 'MIN'
                SET @comparestr= '<'
            END
        END
        SET @sql=N 'SELECT top ' +STR(@pagesize)+N ' ' +@fields+N ' FROM ' +@tablename+N ' WHERE ' +@keyid+@comparestr
            +N '(SELECT ' +@operatestr+N '(' +@keyid+N ') FROM ' +@tablename+N ' WHERE ' +@keyid
            +N ' IN (SELECT TOP ' +STR((@pageindex-1)*@pagesize)+N ' ' +@keyid+N ' FROM ' +@tablename+N ' WHERE '
            +@condition+N ' ' +@orderstr+N ')) AND ' +@condition+N ' ' +@orderstr
        EXEC (@sql)
    END
GO
 
 
--根据ROW_NUMBER() OVER
CREATE PROC [dbo].[proc_select_page_row]
@pageindex INT =1, --当前页数
@pagesize INT =10, --每页大小
@tablename VARCHAR (50)= '' , --表名
@fields VARCHAR (1000)= '*' , --查询的字段集合
@keyid VARCHAR (50)= '' , --主键
@condition NVARCHAR(1000)= '' , --查询条件
@orderstr VARCHAR (500), --排序条件
@totalRecord BIGINT OUTPUT --总记录数
AS
    IF ISNULL (@orderstr,N '' )=N '' SET @orderstr=N ' ORDER BY ' +@keyid+N ' DESC '
    IF ISNULL (@fields,N '' )=N '' SET @fields=N '*'
    IF ISNULL (@condition,N '' )=N '' SET @condition=N '1=1'
    DECLARE @sql NVARCHAR(4000)
--  IF @totalRecord IS NULL
--  BEGIN
        SET @sql=N 'SELECT @totalRecord=COUNT(*)'
            +N ' FROM ' +@tablename
            +N ' WHERE ' +@condition
        EXEC sp_executesql @sql,N '@totalRecord bigint OUTPUT' ,@totalRecord OUTPUT
--END
    IF(@pageindex=1)
    BEGIN
        SET @sql=N 'SELECT TOP ' +STR(@pagesize)+N ' ' +@fields+N ' FROM ' +@tablename+N ' WHERE ' +@condition+N ' ' +@orderstr
        EXEC (@sql)
    END
    ELSE
    BEGIN
        DECLARE @StartRecord INT
        SET @StartRecord = (@pageindex-1)*@pagesize + 1
        SET @sql=N 'SELECT * FROM (SELECT ROW_NUMBER() OVER (' + @orderstr +N ') AS rowId,' +@fields+N ' FROM ' + @tablename+N ') AS T WHERE rowId>=' +STR(@StartRecord)+N ' and rowId<=' +STR(@StartRecord + @pagesize - 1)
        EXEC (@sql)
    END
GO
 
 
--根据TOP ID
CREATE PROC [dbo].[proc_select_page_top]
@pageindex INT =1, --当前页数
@pagesize INT =10, --每页大小
@tablename VARCHAR (50)= '' , --表名
@fields VARCHAR (1000)= '' , --查询的字段集合
@keyid VARCHAR (50)= '' , --主键
@condition NVARCHAR(1000)= '' , --查询条件
@orderstr VARCHAR (500), --排序条件
@totalRecord BIGINT OUTPUT --总记录数
AS
    IF ISNULL (@orderstr,N '' )=N '' SET @orderstr=N ' ORDER BY ' +@keyid+N ' DESC '
    IF ISNULL (@fields,N '' )=N '' SET @fields=N '*'
    IF ISNULL (@condition,N '' )=N '' SET @condition=N '1=1'
    DECLARE @sql NVARCHAR(4000)
    --IF(@totalRecord IS NULL)
    --BEGIN
        SET @sql=N 'SELECT @totalRecord=COUNT(*)'
            +N ' FROM ' +@tablename
            +N ' WHERE ' +@condition
        EXEC sp_executesql @sql,N '@totalRecord INT OUTPUT' ,@totalRecord OUTPUT
    --END
    IF(@pageindex=1)
    BEGIN
        SET @sql=N 'SELECT TOP ' +STR(@pagesize)+N ' ' +@fields+N ' FROM ' +@tablename+N ' WHERE ' +@condition+N ' ' +@orderstr
        EXEC (@sql)
    END
    ELSE
    BEGIN
        SET @sql=N 'SELECT TOP ' +STR(@pagesize)+N ' ' +@fields+N ' FROM ' +@tablename+N ' WHERE  ' +@keyid
        +N ' NOT IN(SELECT TOP ' +STR((@pageindex-1)*@pagesize)+N ' ' +@keyid+N ' FROM '
        +@tablename+N ' WHERE ' +@condition+N ' ' +@orderstr+N ') AND ' +@condition+N ' ' +@orderstr
        EXEC (@sql)
    END
GO

猜你喜欢

转载自javaboychina.iteye.com/blog/1920235