通用分页存储过程(sqlserver)

简介:
+关注继续查看
< DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd>

-- 获取指定页的数据
CREATE PROCEDURE spPagination
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@doCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS

declare @strSQL varchar(5000) -- 主语句
declare @strTmp varchar(110) -- 临时变量
declare @strOrder varchar(400) -- 排序类型
if @doCount != 0
begin
     if @strWhere !=''
      set @strSQL = "select count(*) as Total from [" + @tblName + "] where "
     else
      set @strSQL = "select count(*) as Total from [" + @tblName + "]"
end
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况

else
begin
     if @OrderType != 0
      begin
       set @strTmp = "<(select min"
       set @strOrder = " order by [" + @fldName +"] desc"
       --如果@OrderType不是0,就执行降序,这句很重要!
      end
  
     else
      begin
       set @strTmp = ">(select max"
       set @strOrder = " order by [" + @fldName +"] asc"
      end
      if @PageIndex = 1
       begin
        if @strWhere != ''
         set @strSQL = "select top " + str(@PageSize) +" "+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder
        else
         set @strSQL = "select top " + str(@PageSize) +" "+ " from ["+ @tblName + "] "+ @strOrder
         --如果是第一页就执行以上代码,这样会加快执行速度
       end
      else
       begin
        --以下代码赋予了@strSQL以真正执行的SQL代码
        set @strSQL = "select top " + str(@PageSize) +" "+ " from ["
         + @tblName + "] where [" + @fldName + "]" + @strTmp + "(["+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"+ @strOrder
         if @strWhere != ''
        set @strSQL = "select top " + str(@PageSize) +" "+ " from ["
         + @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
         + @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
         + @fldName + "] from [" + @tblName + "] where " + @strWhere + " "
         + @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder
end
end


exec (@strSQL)
GO

本文转自 netcorner 博客园博客,原文链接:http://www.cnblogs.com/netcorner/archive/2007/06/30/2912349.html  ,如需转载请自行联系原作者

相关实践学习
使用交互方式创建数据表
本次实验主要介绍如何在RDS-SQLServer数据库中使用交互方式创建数据表。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
2月前
|
存储
SqlServer存储过程应用二:分页查询数据并动态拼接where条件 (下)
SqlServer存储过程应用二:分页查询数据并动态拼接where条件 (下)
|
2月前
|
存储 SQL 数据库连接
SqlServer存储过程应用二:分页查询数据并动态拼接where条件 (上)
SqlServer存储过程应用二:分页查询数据并动态拼接where条件
|
2月前
|
存储 SQL 开发框架
SqlServer存储过程的创建与使用
SqlServer存储过程的创建与使用
|
2月前
|
存储
【干货】SqlServer 总结几种存储过程分页的使用
【干货】SqlServer 总结几种存储过程分页的使用
|
2月前
|
存储 程序员
SQLServer存储过程自制数据字典
SQLServer存储过程自制数据字典
|
4月前
|
存储 SQL
sqlserver利用存储过程批量导出excel
sqlserver利用存储过程批量导出excel
|
7月前
|
存储 SQL
sql server 存储过程传递表名参数及Dynamic SQL
sql server 存储过程传递表名参数及Dynamic SQL
sql server 存储过程传递表名参数及Dynamic SQL
|
8月前
|
存储 SQL
vc++中,用ado执行sql server存储过程,并且取得返回值的例子
vc++中,用ado执行sql server存储过程,并且取得返回值的例子
|
9月前
|
存储 SQL 关系型数据库
C# 中的数据库操作~存储过程篇Mysql SqlServer
C# 中的数据库操作~存储过程篇Mysql SqlServer
|
9月前
|
存储 SQL 数据库
sqlserver中常用的几个存储过程
sqlserver中常用的几个存储过程
83 2
推荐文章
更多