分页SQL语句
2017-11-09 16:17
465 查看
CREATE PROC [dbo].[Procpageselect] @table NVARCHAR(max),-- 输入参数,表名 @columns NVARCHAR(max),-- 输入参数,要返回的列 @rows INT,-- 输入参数,每页显示的数据量 @page INT,-- 输入参数,当前页面 @orderBy NVARCHAR(max),-- 输入参数,数据按什么字段排序,后面加上desc表示倒序 @condition NVARCHAR(max),-- 输入参数,sql形式的筛选查询条件 @total INT output -- 输出参数,满足上诉查询条件的数据总数 AS BEGIN DECLARE @start INT -- 变量,获取的当页数据的起始位置 DECLARE @end INT -- 变量,获取的当页数据的结束位置 DECLARE @sql NVARCHAR(max) -- 变量,保存动态生成的sql语句 IF @condition = '' OR @condition IS NULL BEGIN SET @condition = '1=1' END SET @sql = 'select @count = COUNT(*) from ' + @table + ' where ' + @condition EXEC Sp_executesql @sql, N'@count int output', @total output --print(@total) SET @start = @rows * ( @page - 1 ) SET @end = @rows * @page SET @sql = 'with tmp as (select ROW_NUMBER() over(order by ' + @orderBy + ') as [no], ' + @columns + ' from (select * from ' + @table + ' where ' + @condition + ') as a) select * from tmp where [no] > ' + Ltrim(Str(@start)) + ' and [no] <= ' + Ltrim(Str(@end)) --print(@sql) EXEC(@sql) END
相关文章推荐
- 一条SQL语句搞定Sql Server 2000 分页
- SQL分页语句,.NET中获取字符串的MD5码
- 使用SQL语句对表进行分页查询
- 关于SQL语句分页,网上也有很多啦,我贴一部分过来,并且总结自己已知的分页到下面,方便日后查阅。
- oracle排序并分页sql语句
- jsp + oracle 排序分页 高效sql语句
- ORACLE分页SQL语句
- 分页技术--sql语句的分页
- 分享三种高效率SQL语句分页方法
- sql分页语句
- php mssql 分页SQL语句优化 持续影响
- 玩转Web之Jsp(三)-----Jsp+SQLServer 用sql语句实现分页
- 几种常用数据库 分页查询的sql语句和简单分析
- 分页 存储过程 sql语句
- SQL语句简单分页运用
- 一个利用sql 语句来实现分页的存储过程
- 三种SQL分页语句
- 几条常见的数据库分页 SQL 语句
- 主流数据库的分页SQL语句
- SQL分页语句