--通用分页

ALTER PROCEDURE [dbo].[Sys_Pagination_1]

@tblName VARCHAR(2000) , -- 表名

@strGetFields VARCHAR(1000) = '*' , -- 需要返回的列

@fldName VARCHAR(255) = '' , -- 排序的字段名

@PageSize INT = 10 , -- 页尺寸

@PageIndex INT = 1 , -- 页码

@OrderType BIT = 0 , -- 设置排序类型, 非 0 值则降序

@strWhere VARCHAR(2500) = '' -- 查询条件 (注意: 不要加 where)

AS

BEGIN

--处理开始点和结束点

DECLARE @strOrder VARCHAR(400) -- 排序类型

DECLARE @MaxCode NVARCHAR(100) --记录个数

DECLARE @StartRecord INT;

DECLARE @EndRecord INT;

DECLARE @TotalCountSql NVARCHAR(4000);

DECLARE @SqlString NVARCHAR(4000);

SET @StartRecord = ( @PageIndex - 1 ) * @PageSize + 1

SET @EndRecord = @StartRecord + @PageSize - 1

IF @OrderType != 0

BEGIN

SET @strOrder = ' order by ' + @fldName + ' desc'

--如果@OrderType不是0,就执行降序,这句很重要!

END

ELSE

BEGIN

SET @strOrder = ' order by ' + @fldName + ' asc'

END

SET @TotalCountSql = N'select @Max_ID = count(*) from ' + @tblName;--总记录数语句

SET @SqlString = N'(select row_number() over (' + @strOrder

+ ') as rowId,' + @strGetFields + ' from ' + @tblName;--查询语句

IF ( @strWhere ! = ''

OR @strWhere != NULL

)

BEGIN

SET @TotalCountSql = @TotalCountSql + ' where ' + @strWhere;

SET @SqlString = @SqlString + ' where ' + @strWhere;

END

--第一次执行得到

--IF(@TotalRecord is null)

-- BEGIN

EXEC sp_executesql @totalCountSql, N'@Max_ID varchar(100) output',

@MaxCode OUTPUT;--返回总记录数

PRINT @totalCountSql

-- END

----执行主语句

SET @SqlString = 'select ' + @strGetFields + ' from ' + @SqlString

+ ') as t where rowId between ' + LTRIM(STR(@StartRecord))

+ ' and ' + LTRIM(STR(@EndRecord));

EXEC(@SqlString)

PRINT @SqlString

RETURN @MaxCode

END

SQL 分页实现的更多相关文章

  1. sql分页操作

    看到了网上关于分页的讲解  对最快的分页语句做了测试 还别说速度真快 总共6w条数据 速度确实so 快 前提是id是主键 或者是索引 declare @page int;--页数 declare @P ...

  2. SQL Server SQL分页查询

    SQL Server SQL分页查询的几种方式 目录 0.    序言 1.    TOP…NOT IN… 2.    ROW_NUMBER() 3.    OFFSET…FETCH 4.    执行 ...

  3. sql分页代码

    //三种sql分页语句 SELECT TOP 分页尺寸 * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM Blob ...

  4. SQL分页查询结果不一致

    今天遇到了SQL分页查询结果不一致的情况,一看代码,原来是没加排序查询!!分页查询最好加排序,且以唯一性高的字段进行排序,如ID,时间等,以保持每页查询结果的准确! PS:又帮别人擦屁股!!

  5. 真正通用的SQL分页存储过程

    关于SQL分页的问题,网上找到的一些SQL其实不能真正做到通用,他们主要是以自增长ID做为前提的.但在实际使用中,很多表不是自增长的,而且主键也不止一个字段,其实我们稍做改进就可以达到通用.这里还增加 ...

  6. oracle15 pl/sql 分页

    PL/SQL分页 编写分页过程 无返回值的存储过程 古人云:欲速则不达,为了让大家伙比较容易接受分页过程编写,我还是从简单到复杂,循序渐进的给大家讲解.首先是掌握最简单的存储过程,无返回值的存储过程: ...

  7. [转]关于SQL分页存储过程的分析

    [转]关于SQL分页存储过程的分析 建立一个 Web 应用,分页浏览功能必不可少.这个问题是数据库处理中十分常见的问题.经典的数据分页方法是:ADO 纪录集分页法,也就是利用ADO自带的分页功能(利用 ...

  8. SQL点滴16—SQL分页语句总结

    原文:SQL点滴16-SQL分页语句总结 今天对分页语句做一个简单的总结,他们大同小异的,只要理解其中一个其他的就很好理解了. 使用top选项 *from Orders orderid from Or ...

  9. oracle sql 分页

    Oracle实现分页时,需要引入一个rownum的函数,rownum可以给记录一个类似于id的字段. 以下收整理了常用的几种sql分页算法,数据库以Oracle中emp为例.查询结果如下: SQL&g ...

  10. pageHelper多个sql分页

    之前有个需求,在一个页面中需要有多个sql分页查询然后放到一个list中,展示,但是会出现一个bug,就是每次分页都会展示第一条查出的所有的数据: 第一页 第二页 因为是截的生产环境,第一条数据被处理 ...

随机推荐

  1. js提交数据时需判断是点击事件还是回车键

    使用回车键实质还是点击事件==回车时将焦点聚居在某个标签上. Html代码: <div id="btlogin" class="btlogin">& ...

  2. SVN客户端下载和Svn visual studio插件

    1.Visual SVN Visual SVN visual studio插件 https://www.visualsvn.com/vis... 2.TortoiseSVN SVN客户端下载 http ...

  3. jquery 键盘事件的使用方法详解

    转自:https://www.jb51.net/article/123579.htm jQuery处理键盘事件有三个函数,根据事件发生的顺序分别是: jquery 代码: 1.  keydown(); ...

  4. ffmpeg+HLS实现直播与回放

    Nginx配置视频服务器 server { listen ; server_name localhost; location /hls{ add_header Access-Control-Allow ...

  5. (转)64位系统安装Delphi7提示Can’t load package:dclite70.bpl 以及 提示地址错误

    第一个问题: 今天在64的Win7上安装Delphi7,在启动时候出现如下提示: Can't load package:dclite70.bpl 告诉大家一个解决办法,就是给Delphi32.exe去 ...

  6. AngularJs(Part 7)--Build-in Directives

    Directives In AngularJS, we can use a variety of naming conventions to reference directives . In the ...

  7. zookeeper-3.4.5-cdh5.1.0 完全分布式安装

    1.环境 主机名 IP地址 JDK ZooKeeper myid c1 192.168.58.129 1.7.0_11 server.1 1 c2 192.168.58.130 1.7.0_11 se ...

  8. 5、bam格式转为bigwig格式

    1.Bam2bigwig(工具) https://www.researchgate.net/publication/301292288_Bam2bigwig_a_tool_to_convert_bam ...

  9. 22. CTF综合靶机渗透(十五)

    靶机说明: Game of Thrones Hacking CTF This is a challenge-game to measure your hacking skills. Set in Ga ...

  10. Unity -- AssetBundle(本地资源加载和加载依赖关系)

    1.本地资源加载 1).建立Editor文件夹 2).建立StreamingAssets文件夹和其Windows的子文件夹 将下方第一个脚本放入Editor 里面 脚本一  资源打包AssetBund ...