CREATE PROCEDURE [dbo].[UP_GetRecordByPage]
@tblName varchar(255), -- 表名
@fldName varchar(255), -- 主键字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@IsReCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(max) = '' -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(max) -- 主语句
declare @strTmp varchar(max) -- 临时变量(查询条件过长时可能会出错,可修改100为1000)
declare @strOrder varchar(400) -- 排序类型
if @OrderType != 0
begin
set @strTmp = '<(select min'
set @strOrder = ' order by [' + @fldName +'] desc'
end
else
begin
set @strTmp = '>(select max'
set @strOrder = ' order by [' + @fldName +'] asc'
end
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
if @PageIndex = 1
begin
set @strTmp =''
if @strWhere != ''
set @strTmp = ' where ' + @strWhere
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
+ @tblName + ']' + @strTmp + ' ' + @strOrder
end
--if @IsReCount != 0
--set @strSQL = 'select count(*) as Total from [' + @tblName + ']'+' where ' + @strWhere
--exec (@strSQL) if @IsReCount != 0
begin
if @strWhere != ''
set @strSQL = @strSQL + ';' + 'select count(*) as Total from [' + @tblName + ']' + ' where ' + @strWhere
else
set @strSQL = @strSQL + ';' + 'select count(*) as Total from [' + @tblName + ']'
end exec (@strSQL)
select @strSQL

  

最新文章

  1. Linux学习内容
  2. 剑指Offer面试题:16.合并两个排序的链表
  3. APIPA(Automatic Private IP Addressing,自动专用IP寻址)
  4. C语言学习010:fopen读写文件
  5. 关于只针对ie7浏览器的css问题
  6. SQL:with ties
  7. Linear Regression
  8. UMA - Unity Multipurpose Avatar
  9. keyboard splitting bug on ipad with ios 5 and 6 (Cocos2d-x)
  10. Storm官方文档翻译之创建Storm项目
  11. 纯css美化单选、复选框
  12. Weblogic Exception in AppMerge flows&#39; progression
  13. Asp.Net Core 轻松学-基于微服务的后台任务调度管理器
  14. Ubuntu下的 PPPoE 拨号上网方法
  15. Coursera, Deep Learning 5, Sequence Models, week3, Sequence models &amp; Attention mechanism
  16. Fiddler的安装与使用
  17. 具有相同名称 的类/接口已在使用。请使用类定制设置来解决此冲突。java调用第三方的webservice应用实例
  18. python序列元素引用容易出错的地方
  19. ES6基础三(对象)
  20. Linux 编译时内存不足

热门文章

  1. Linux如何实现进程监控和守护
  2. 某里巴巴Java工程师常规面试题以及解答
  3. 学号 20175201张驰 《Java程序设计》第4周学习总结
  4. [py]pandas数据统计学习
  5. Javascript扩展String.prototype实现格式金额、格式时间、字符串连接、计算长度、是否包含、日期计算等功能
  6. JS中的闭包(转自他处)
  7. 插播一则关于HTTP Headers详解~~~
  8. 详解Nginx服务器配置
  9. ASP.NET MVC案例教程(四)
  10. 一个spinner控件使用的实例