项目中用到的SQLServer分页查询存储过程。

【存储过程】

create PROCEDURE prcPageResult

-- 获得某一页的数据 --

@currPage int = 1,                         --当前页页码 (即Top currPage)

@showColumn varchar(2000) = '*',           --须要得到的字段 (即 column1,column2,......)

@strCondition varchar(2000) = '',          --查询条件 (即 where condition......) 不用加wherekeyword

@ascColumn varchar(100) = '',              --排序的字段名 (即 order by column asc/desc)

@bitOrderType bit = 0,                     --排序的类型 (0为升序,1为降序)

@pkColumn varchar(50) = '',                --主键名称

@pageSize int = 20,                        --分页大小

@RecordCount int output --返回总行数





AS

BEGIN -- 存储过程開始

-- 该存储过程须要用到的几个变量 --

DECLARE @strTemp varchar(1000)

DECLARE @strSql varchar(4000)                   --该存储过程最后运行的语句

DECLARE @strSql01 varchar(4000) 

DECLARE @strOrderType varchar(1000)      --排序类型语句 (order by column asc或者order by column desc)









BEGIN

IF @bitOrderType = 1   -- bitOrderType=1即运行降序

BEGIN

    SET @strOrderType = ' ORDER BY '+@ascColumn+' DESC'

    SET @strTemp = '<(SELECT min'

END

ELSE

BEGIN

    SET @strOrderType = ' ORDER BY '+@ascColumn+' ASC'

    SET @strTemp = '>(SELECT max'

END





IF @currPage = 1    -- 假设是第一页

BEGIN

    IF @strCondition != ''

        SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM dbo.DemoData '+

            ' WHERE '+@strCondition+@strOrderType

    ELSE

        SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM dbo.DemoData '+@strOrderType

END





ELSE    -- 其它页

BEGIN

    IF @strCondition !=''

        SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM dbo.DemoData '+

        ' WHERE '+@strCondition+' AND '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currPage-1)*@pageSize)+

        ' '+@pkColumn+' FROM dbo.DemoData '+@strOrderType+') AS TabTemp)'+@strOrderType

    ELSE

        SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@showColumn+' FROM dbo.DemoData '+

        ' WHERE '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currPage-1)*@pageSize)+' '+@pkColumn+

        ' FROM dbo.DemoData '+@strOrderType+') AS TabTemp)'+@strOrderType

END



END

select @RecordCount=COUNT(*) from dbo.DemoData

EXEC (@strSql)





END  -- 存储过程结束

------------------------------------------------

GO

【调用方式】

DECLARE @RecordCount int

exec prcPageResult 1,'*','','id',1,'id',10,@RecordCount out

SELECT @RecordCount

---

DECLARE @RecordCount int

exec prcPageResult 1,'*','name=''hugh''','id',0,'id',10,@RecordCount out
--存储过程中转义字符为‘。所以name=’hugh'正确的写法应该是'name=''hugh'''而不是'name=/'hugh/''

SELECT @RecordCount

SQLServer分页查询存储过程的更多相关文章

  1. 高效的SQLSERVER分页查询的几种示例分析

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  2. 真正高效的SQLSERVER分页查询(多种方案)

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  3. SQLserver分页查询实例

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  4. 高效的SQLSERVER分页查询(推荐)

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  5. 高效的SQLSERVER分页查询

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  6. ADO调用分页查询存储过程

    一.分页存储过程 ----------使用存储过程编写一个分页查询----------------------- set nocount off --关闭SqlServer消息 --set nocou ...

  7. SQLSERVER分页查询

    转:http://blog.csdn.net/qiaqia609/article/details/41445233   Sqlserver数据库分页查询一直是Sqlserver的短板,   第一种方案 ...

  8. SQLServer分页查询笔记

    学习SqlServer到现在快两年了吧,分页查询总是忘了看笔记,看了又忘.之前用的分页都是row_number函数的方式,背不住...直到今天,看到别人写的另一种分页写法,看似比row_number简 ...

  9. Oracle/MySql/SQL Sqlserver分页查询

    简述 简单概括一下Oracle,MySql,SQL Sqlserver这三个数据库的分页查询语句. Oracle分页查询 例:每页显示两条数据,现在要查询第二页,也就是第3-4条数据. 查询语句: s ...

随机推荐

  1. Quiz 6b Question 7————An Introduction to Interactive Programming in Python

     Question 7 Convert the following English description into code. Initialize n to be 1000. Initiali ...

  2. COM编程-注册DLL形式的COM服务器

    这篇文章不涉及任何的有关COM的技术的讲解,仅仅的说一下写好的DLL形式的COM怎么使用.如下图所示,我已经有了一个DLL形式的COM服务器和一个使用COM服务器的COM客户端: 现在这个DLL的CO ...

  3. 如何正确的在java web配置数据池

    在tomcat context.xml中配置数据 <Context reloadable="true"> <!-- Default set of monitore ...

  4. Jsunpack

    http://www.baidu.com/#wd=jsunpack&rsv_bp=0&tn=baidu&rsv_spt=3&ie=utf-8&rsv_sug3= ...

  5. Windows Phone 8初学者开发—第12部分:改进视图模型和示例数据

    原文 Windows Phone 8初学者开发—第12部分:改进视图模型和示例数据 第12部分:改进视图模型和示例数据 原文地址:http://channel9.msdn.com/Series/Win ...

  6. Python: 在Unicode和普通字符串之间转换

    Unicode字符串可以用多种方式编码为普通字符串, 依照你所选择的编码(encoding): <!-- Inject Script Filtered --> Toggle line nu ...

  7. Windows Azure 社区新闻综述(#75 版)

    欢迎查看最新版本的每周综述,其中包含有关云计算和 Windows Azure 的社区推动新闻.内容和对话.以下是本周的亮点. 文章.视频和博客文章 ·   PowerShell 对 Windows A ...

  8. java学习之生产者和消费者案例

    package com.gh.thread; /** * 生产者和消费者案例 * wait和sleep的区别 * wait不让出监视器锁,sleep让出监视器的锁 * @author ganhang ...

  9. CodeForces 525C Ilya and Sticks 贪心

    题目:click here #include <iostream> #include <cstdio> #include <cstring> #include &l ...

  10. linux添加、修改环境变量

    比如要把/etc/apache/bin目录添加到PATH中,方法有三: 1.In shell: setenv <path_to_append>: $ENVNAME setenv PATH ...