SQL分页存储过程
来源:互联网 发布:付费ss 知乎 编辑:程序博客网 时间:2024/04/30 05:34
自己写的一个SQL分页存储过程,原理来自网上的一篇文章,
原理为:
原理为:
select top 页大小 *
from table1
where id>
(select max (id) from
(select top ((页码-1)*页大小) id from table1 order by id) as T
)
from table1
where id>
(select max (id) from
(select top ((页码-1)*页大小) id from table1 order by id) as T
)
CREATE procedure GetLYZXNews
@type int, --文章类型
@Pgs int, --页大小
@Pgn int --页码,页码为0则为求总页数
as
declare @strsql varchar(500) --执行的SQL语句
declare @ZongShu int --记录总数
declare @YeShu int --总页数
declare @strTmp int --临时变量
if @Pgn = 0
begin
select @ZongShu=count(*) from LYNews where type=@type
if @ZongShu<=@Pgs
begin
if @ZongShu=0
begin
set @YeShu=0
end
else
begin
Set @YeShu=1
end
end
else
begin
set @strTmp=@ZongShu % @Pgs
if @strTmp = 0
begin
set @YeShu=@ZongShu/@Pgs
end
else
begin
set @YeShu=@ZongShu/@Pgs+1
end
end
set @strsql="select "+str(@ZongShu)+" as ZongShu,"+str(@YeShu)+" as YeShu"
end
else
begin
if @Pgn=1
begin
set @strsql="select top "+str(@Pgs)+" * from LyNews Where type="+str(@type)+" order by postDate desc"
end
else
begin
set @strsql="select top "+str(@Pgs)+" * from LyNews Where type="+str(@type)+" and postDate<(select min(postDate) from "
set @strsql=@strsql+"(select top "+str((@Pgn-1)*@Pgs)+" * from LyNews where type="+str(@type)+" order by postdate desc)as t) order by postDate desc"
end
end
exec (@strSQL)
GO
@type int, --文章类型
@Pgs int, --页大小
@Pgn int --页码,页码为0则为求总页数
as
declare @strsql varchar(500) --执行的SQL语句
declare @ZongShu int --记录总数
declare @YeShu int --总页数
declare @strTmp int --临时变量
if @Pgn = 0
begin
select @ZongShu=count(*) from LYNews where type=@type
if @ZongShu<=@Pgs
begin
if @ZongShu=0
begin
set @YeShu=0
end
else
begin
Set @YeShu=1
end
end
else
begin
set @strTmp=@ZongShu % @Pgs
if @strTmp = 0
begin
set @YeShu=@ZongShu/@Pgs
end
else
begin
set @YeShu=@ZongShu/@Pgs+1
end
end
set @strsql="select "+str(@ZongShu)+" as ZongShu,"+str(@YeShu)+" as YeShu"
end
else
begin
if @Pgn=1
begin
set @strsql="select top "+str(@Pgs)+" * from LyNews Where type="+str(@type)+" order by postDate desc"
end
else
begin
set @strsql="select top "+str(@Pgs)+" * from LyNews Where type="+str(@type)+" and postDate<(select min(postDate) from "
set @strsql=@strsql+"(select top "+str((@Pgn-1)*@Pgs)+" * from LyNews where type="+str(@type)+" order by postdate desc)as t) order by postDate desc"
end
end
exec (@strSQL)
GO
- sql 存储过程分页
- sql 存储过程分页
- sql分页存储过程
- sql分页存储过程
- sql 存储过程分页
- sql 存储过程分页
- SQL 存储过程---分页
- 分页存储过程--sql
- sql存储过程 分页
- sql 存储过程分页
- SQL 分页存储过程
- SQL分页存储过程
- sql分页存储过程
- SQL分页存储过程
- sql分页存储过程
- SQL ----存储过程分页
- SQL分页存储过程
- SQL----分页存储过程
- 把爱情程序化——给女程序员的情书
- 编码人员和美工的配合问题
- Java中static的理解
- 怎么在XP下安装Linux啊???
- c++之全排列字典序法
- SQL分页存储过程
- 睡觉睡觉
- 初中数学公式大全
- MFC努力中。。。
- 高中数学公式大全
- ESOE-IDE v0.3 技术说明书
- IO流定时器
- java 调用操作系统的命令
- 创建XMLHttpRequest