最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
SQL分页查询存储过程实例代码
时间:2022-06-29 07:49:37 编辑:袖梨 来源:一聚教程网
话不多说,请看代码
|
-------------------------------------
-----作者:张欣宇
-----时间:2013-06-28
-----简介:根据参数和条件分页查询
-------------------------------------
Createproc [dbo].[Up_PagingQueryByParameter]
(
----- 表名或能查询到结果的SQL语句{SQL语句左右必须有括号例:(select * from tbl1)}
@TableNamevarchar(max),
----- 要查询的列名语句; 可空默认*
@ColumnNamevarchar(5000),
----- 用来排序的列; 不可为空
@OrderByColumnNamevarchar(50),
----- 排序desc(倒序5.4.3.2.1)或asc(正序1.2.3.4.5); 可空默认asc
@ShrtByvarchar(4),
----- Where条件; 可空默认1=1
@Wherevarchar(5000),
----- 每页显示数; 可空默认20
@PageShowsint,
----- 当前页数; 可空默认1
@CurrentPageint,
----- 0为分页查询;其他为查询全部; 可空默认0
@IsPagingint
)
as
begin
----- 参数检查及规范
ifisnull(@Where,N'')=N''set@Where= N'1=1';
ifisnull(@ColumnName,N'')=N''set@ColumnName = N'*';
ifisnull(@PageShows,0)<1set@PageShows = 20;
ifisnull(@CurrentPage,0)<1set@CurrentPage = 1;
ifisnull(@ShrtBy,N'')=N''set@ShrtBy ='asc';
ifisnull(@IsPaging,0)<>1set@IsPaging = 0;
----- 定义
-- 拼接的SQL语句
declare@SqlStr nvarchar(max);
declare@SqlWithStr nvarchar(max);
-- 开始条数
declare@StartIndexint;
-- 结束条数
declare@EndIndexint;
----- 赋值
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
|
相关文章
- 抖音官方充值入口-抖音充值活动任务奖励领取入口 12-18
- 哔哩哔哩在线免费畅看-2025哔哩哔哩b站网页版最新入口速览 12-18
- 一人之下漫画免费在线观看入口 | 实时缓存无延迟,网页直读免下载 12-18
- 免费PPT成品网站直播推荐-超全免费PPT模板网站盘点 12-18
- 学信网查学历-官方学历查询入口(一键验证学历信息) 12-18
- 虫虫漫画-免费漫画观看入口_海量正版漫画在线畅读平台 12-18