使用存储过程实现分页
来源:互联网 发布:windows安全中心闪退 编辑:程序博客网 时间:2024/05/16 08:20
CREATE PROCEDURE GetRecordFromPage
@tblName varchar(255), -- 表名
@fldName varchar(255), -- 字段名以主键值
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(2000) = '' -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(6000) -- 主语句
declare @strTmp varchar(5000) -- 临时变量
declare @strOrder varchar(500) -- 排序类型
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
--print @strSQL
exec (@strSQL)
GO
- 使用存储过程实现分页
- 使用存储过程实现分页打印
- 使用存储过程实现分页打印
- 数据库分页处理--使用存储过程实现
- 使用存储过程实现分页效果
- DataList使用存储过程实现分页
- DropDownList使用存储过程实现分页
- oracle中使用存储过程实现分页
- 使用系统存储过程实现的通用分页存储过程
- 使用系统存储过程实现的通用分页存储过程
- 存储过程实现分页
- 存储过程实现分页
- 存储过程实现分页
- 存储过程实现分页
- 使用存储过程分页
- 使用存储过程分页
- 使用存储过程分页
- 存储过程使用:分页存储
- 取消windows默认共享
- 彻底删除微软拼音输入法2003
- 水晶报表分页小计
- **新家**
- javascript 模拟Dreamweaver开发的纯文本查询器
- 使用存储过程实现分页
- 通用的数据分页的存储过程
- 如何让IE窗口再次最大化
- 优秀网址
- Asp.net页面输出到EXCEL
- 处理在DataGrid中的DropDownList的事件
- Windows Mobile5.0 10月18日笔记:RDADemo
- 原来的blog所在服务器突然就关了。我现在的mail:pediy3000@hotmail.com
- 写Dll时遇到的一个错误