存储过程进行分页

本文介绍了一种使用 Oracle PL/SQL 实现分页查询的方法。通过创建存储过程 `fenye`,输入 SQL 语句及分页参数,返回指定页数的数据记录。该方法包括计算起始和结束记录数、构建分页 SQL、获取总记录数并计算总页数等功能。
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
  create or replace procedure fenye(
  v_in_sql in varchar2,--待分页的SQL
  v_in_pagesize in number,--每页显示记录数
  v_in_pagenow in number,--当前页数
  v_out_result out cursor_type_page.my_cursor,--返回结果集
  v_out_rows out number,--记录总数
  v_out_pagecount out number--总页数
) is
--定义变量
v_sql varchar2(2000);
v_start number;
v_end number;
begin
  --开始记录数
v_start:=v_in_pagesize*(v_in_pagenow-1)+1;
--结束记录数
v_end:=v_in_pagenow*v_in_pagesize;
--分页SQL实现
v_sql:=select * from
  (select t.*,rownum rn from
    (v_in_sql) t where rownum<='||v_end||') where rn>='||v_start||';
 
--打开游标
open v_out_result for v_sql;
--查询共有多少条记录
select count(*) into v_out_rows from  (v_in_sql);
--计算总页数
if mod(v_out_rows,v_in_pagesize)=0 then
  v_out_pagecount:=v_out_rows/v_in_pagesize;
  else
     v_out_pagecount:=v_out_rows/v_in_pagesize+1;
     end if;
  end;
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值