分页的存储过程

create or replace PROCEDURE  PROCEDURE1
(
--输入参数
currentPage IN INT, --当前页
pagerows IN INT, --每页行数

--输出参数
totalpages OUT INT, --总的页数
totalrows OUT INT, --总的条数
hasnext OUT INT, --是否有下一页
hasprovious OUT INT,--是否有上一页
c_emp out c_cursor09.mytype--游标(先在包中定义ref游标)
) AS
currentrows int;
BEGIN
  --得到总的条数
  select count(*)  into totalrows from emp;
 
  --经过判断得到总页数
  if mod(totalrows,pagerows)=0 then
    totalpages:=totalrows/pagerows;
  else
    totalpages:=totalrows/pagerows+1;
  end if;
 
  --是否上一页
  if currentpage=1 then
    hasprovious:=0;
  else
    hasprovious:=1;
  end if;
 
  --是否下一页
  if currentpage=totalpages then
    hasnext:=0;
  else
    hasnext:=1;
  end if;
 
  --rownum从1开始所以currentrows需要加1
  currentrows:=currentpage*pagerows-pageRows+1;
 
  open c_emp for
  select empno from (select rownum r,emp.* from emp)
  where r<currentrows+pagerows and r>=currentrows;
 
END;
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值