三种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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值