首页 / MYSQL / SQL分页查询存储过程代码分享
SQL分页查询存储过程代码分享
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQL分页查询存储过程代码分享,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2550字,纯文字阅读大概需要4分钟。
内容图文
![SQL分页查询存储过程代码分享](/upload/InfoBanner/zyjiaocheng/584/e49d291ee481480c89d8348b3af8b7a5.jpg)
话不多说,请看代码
------------------------------------- -----作者:张欣宇 -----时间:2013-06-28 -----简介:根据参数和条件分页查询 ------------------------------------- Create proc [dbo].[Up_PagingQueryByParameter] ( ----- 表名或能查询到结果的SQL语句{SQL语句左右必须有括号例:(select * from tbl1)} @TableName varchar(max), ----- 要查询的列名语句; 可空默认* @ColumnName varchar(5000), ----- 用来排序的列; 不可为空 @OrderByColumnName varchar(50), ----- 排序desc(倒序5.4.3.2.1)或asc(正序1.2.3.4.5); 可空默认asc @ShrtBy varchar(4), ----- Where条件; 可空默认1=1 @Where varchar(5000), ----- 每页显示数; 可空默认20 @PageShows int, ----- 当前页数; 可空默认1 @CurrentPage int, ----- 0为分页查询;其他为查询全部; 可空默认0 @IsPaging int ) as begin ----- 参数检查及规范 if isnull(@Where,N'')=N'' set @Where = N'1=1'; if isnull(@ColumnName,N'')=N'' set @ColumnName = N'*'; if isnull(@PageShows,0)<1 set @PageShows = 20; if isnull(@CurrentPage,0)<1 set @CurrentPage = 1; if isnull(@ShrtBy,N'')=N'' set @ShrtBy = 'asc'; if isnull(@IsPaging,0)<>1 set @IsPaging = 0; ----- 定义 -- 拼接的SQL语句 declare @SqlStr nvarchar(max); declare @SqlWithStr nvarchar(max); -- 开始条数 declare @StartIndex int; -- 结束条数 declare @EndIndex int; ----- 赋值 set @StartIndex = (@CurrentPage-1)*@PageShows+1; print(@CurrentPage); print(@PageShows); print(@StartIndex); set @EndIndex = @CurrentPage*@PageShows; print(@EndIndex); set @OrderByColumnName=@OrderByColumnName+' '+@ShrtBy; ----- 分页查询 set @SqlWithStr = N'with temp as(select ROW_NUMBER() over(order by '+@OrderByColumnName+N') as RowNumber,'+@ColumnName+N' from '+@TableName+N' as tableName where '+@Where+N')'; if(@IsPaging = 0) begin set @SqlStr = @SqlWithStr + N' select '+@ColumnName+N' from temp where temp.RowNumber between '+convert(nvarchar(20),@StartIndex)+N' and '+convert(nvarchar(20),@EndIndex)+N''; ---- print(@SqlStr); exec(@SqlStr); ----- 总数查询 set @SqlStr = @SqlWithStr + N' select count(*) as TotalNumber from temp'; ---- print(@SqlStr); exec(@SqlStr); end else begin set @SqlStr = @SqlWithStr + N' select '+@ColumnName+N' from temp'; ---- print(@SqlStr); exec(@SqlStr); end end
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!
您可能感兴趣的文章:
- 五种SQL Server分页存储过程的方法及性能比较
- SQL Server 分页查询通用存储过程(只做分页查询用)
- sqlserver2005利用临时表和@@RowCount提高分页查询存储过程性能示例分享
- 深入sql server 2005 万能分页存储过程的详解
- 基于Sql Server通用分页存储过程的解决方法
- mssql 高效的分页存储过程分享
- SQL Server 2005通用分页存储过程及多表联接应用
- MSSQL MySQL 数据库分页(存储过程)
- 三种SQL分页查询的存储过程代码
- SQL通用存储过程分页,支持多表联合
内容总结
以上是互联网集市为您收集整理的SQL分页查询存储过程代码分享全部内容,希望文章能够帮你解决SQL分页查询存储过程代码分享所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。