sql高效率分页
来源:互联网 发布:英剧推荐知乎 编辑:程序博客网 时间:2024/06/05 20:53
通用的分页存储过程
CREATE PROCEDURE Pagination @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 "+@strWhere else set @strSQL = "select count(*) as Total from [" + @tblName + "]" end --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况 else begin if @OrderType != 0 // 降序(desc) begin set @strTmp = "<(select min" set @strOrder = " order by [" + @fldName +"] desc" --如果@OrderType不是0,就执行降序,这句很重要! end else // 升序(asc) begin set @strTmp = ">(select max" set @strOrder = " order by [" + @fldName +"] asc" end if @PageIndex = 1 // 页码 begin if @strWhere != '' set @strSQL = "select top " +str(@PageSize)+ " " +@strGetFields+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder else set @strSQL = "select top " +str(@PageSize)+" " +@strGetFields+ " from [" +@tblName+ "] " +@strOrder --如果是第一页就执行以上代码,这样会加快执行速度 end else begin --以下代码赋予了@strSQL以真正执行的SQL代码 set @strSQL = "select top " +str(@PageSize)+ " " +@strGetFields+ " 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)+ " " +@strGetFields+ " 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
单独分页sql语句
--sql语句中 pagesize表明每页记录条数 pageindex表示页码 table表示表明,id表示table表中的主键select top pagesize * from table1 where id > ( select isnull(max(id),0) from (select top (pagesize * (pageindex-1)) id from table1 order by id ) tb)
- sql高效率分页
- Oracle高效率SQL分页,含Informix分页
- 三种高效率SQL语句分页方法
- 一个高效率的SQL Server分页语句
- 三种高效率SQL语句分页方法
- SQL Server三种高效率分页方法
- 高效率的Access\MSSQL分页的SQL语句
- sqlserver高效率分页实现
- asp高效率分页代码
- SQLserver分页 高效率
- 各数据库高效率分页
- 高效率分页查询语句
- ListView高效率分页--笔记
- SQLserver分页 高效率
- Django高效率分页方法
- SQLsever分页 高效率
- 高效率orlace分页
- Web开发中一种用sql语句完成分页的高效率方法(1)
- 别人画表象,我画内在——新锐100设计师林晨专访
- 当前session id
- Qt5.0.2 + MinGW编译出来的程序发布
- 比较好的资料共享
- HDU 1088 (模拟)使用<sstream>模版库
- sql高效率分页
- 代理模式
- ORACLE备份恢复
- Solr学习笔记四--solrj的使用(更新文档)
- Java中switch语句
- hdu1088
- ssh login without passwd
- 可以直接拿来用的15个jQuery代码片段
- tree命令自动生成目录树