今天在做基于ajaxpro分页的时候,发现如果按照前一篇文章所指示,和gridview交互很是不方便,于是就写了基于存储过程和DataTable的分页,主要是存储过程,我就把存储过程给出,其他的很简单,就不再列出
 1sql 分页--分页存储过程
 2sql 分页create procedure GetNews
 3sql 分页(
 4sql 分页  @type int,--文章的类型
 5sql 分页  @pgs int,--页大小
 6sql 分页  @pgn int--页码,页码为0为求总也数
 7sql 分页)
 8sql 分页as
 9sql 分页declare @strsql nvarchar(500--执行的sql语句
10sql 分页declare @zongshu int--纪录总数
11sql 分页declare @yeshu int --总页数
12sql 分页declare @strtemp int--临时变量
13sql 分页if @pgn=0
14sql 分页  begin
15sql 分页     select @zongshu=count(*from LYNews where newstype=@type
16sql 分页    if @zongshu<=@pgs
17sql 分页        begin
18sql 分页          if @zongshu=0
19sql 分页
20sql 分页                 set @yeshu=0
21sql 分页            
22sql 分页           else           
23sql 分页             set  @yeshu=1             
24sql 分页        end
25sql 分页     else--如果@zongshu>@pgs那么开始计算分页,如果@zongshu%@pgs=0的话,就说明每页都是慢的,如果不是的话,那么将存在多余的占一页
26sql 分页         begin
27sql 分页          set @strtemp=@zongshu%@pgs  --如果@zongshu%@pgs=0的话,就说明每页都是满的,如果不是的话,那么将存在多余的纪录占一页
28sql 分页           if @strtemp=0
29sql 分页             
30sql 分页                set @yeshu=@zongshu/@pgs
31sql 分页            
32sql 分页           else
33sql 分页              begin
34sql 分页                set @yeshu=@zongshu/@pgs+1--否则的话那么得在添加一页来显示多余的数据
35sql 分页              end
36sql 分页             set @strsql='select '+str(@zongshu)+' as zongshu, '+str(@yeshu)+' as yeshu'  --返回总页数和总纪录数
37sql 分页          end   
38sql 分页end 
39sql 分页else 
40sql 分页   begin
41sql 分页    if @pgn=1
42sql 分页      
43sql 分页         set @strsql='select top '+str(@pgs)+'  * from Lynews where newstype='+str(@type)+' order by postdate desc'--返回第一页的纪录
44sql 分页       
45sql 分页    else
46sql 分页     
47sql 分页      set @strsql='select top '+str(@pgs)+' * from LyNews Where newstype='+str(@type)+' and postdate<(select min(postdate)  from (select top '+str((@pgn-1)*@pgs)+' * from  LyNews  where newstype='+str(@type)+' order by postdate desc ) as t) order by postdate desc'
48sql 分页      
49sql 分页   end
50sql 分页exec (@strsql)
51sql 分页go

相关文章:

  • 2022-12-23
猜你喜欢
  • 2021-08-12
  • 2021-06-14
  • 2021-06-27
  • 2021-10-25
相关资源
相似解决方案