利用pl/sql过程编写分页

本文介绍了一种在Oracle数据库中实现分页查询的方法,通过创建存储过程并利用ROWNUM进行记录筛选,实现了灵活的分页功能。此外,还提供了如何在Java应用程序中调用此存储过程的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在分页时,大家可以把下面的sql语句当作是一个模板使用
select * from
(select t1.*,rownum rn from (select * from emp) t1 where rownum<=10)
where rn>= 6;
 

 

=============下面是分页创建的具体过程===============


----------开发一个包
 --------1.创建一个包,在该包中,定义类型test_cursor,是个游标
   create or replace package tespackage as
   type test_cursor is ref cursor;
   end tespackage;
  
-----------开始编写分页的过程

create or replace procedure fenye
(tableName in varchar2,
pageSize in number,
pageNow in number,
myRows out number,---总记录数
myPageCount out number,---总页数
p_cursor out tespackage.test_cursor---返回的记录集
) is
---定义部分
---定义sql语句  字符串
v_sql varchar2(1000);


--定义两个整数
v_begin number:= (pageNow-1)*pageSize + 1;
v_end number:=pageNow*pageSize;


begin
---执行部分
v_sql:='select * from (select t1.*,rownum rn from (select * from '||tableName||)' t1 where rownum<='||v_end||') where rn>'||v_begin;


----把游标和sql关联
open p_cursor for v_sql;


----计算myrows和myPageCount
----组织一个sql
v_sql:='select count(*) from'||tableName;


----执行sql,并把返回的值,赋给myRows
execute immediate v_sql into myrows;


------计算myPageCount
if mod(myRows,pageSize)=0 then
myPageCount = myRows/pageSize;
else
myPageCount = myRows/pageSize+1;
end if;
-----关闭游标
---close p_cursor;
end;
end;
  
----------在java中调用过程
 public static void main(String[] args){
        Class.forName("oracle.jdbc.driver.OracleDriver");
        Connection conn = DriverManger.getConnection
        ("jdbc:oracle:thin:@127.0.0.1:1521:YANER","yaner","y327");
         CallableStatement cs = conn.prepareCall("{call fenye(?,?,?,?,?,?)}");
         //给?赋值
          cs.setString(1,"emp");
          cs.setInt(2,5);
          cs.setInt(3,1);
 
        //注册总记录数
        cs.registerOutParameter(4,oracle.jdbc.OracleTypes.INTEGER);
        //注册总页数
        cs.registerOutParameter(5,oracle.jdbc.OracleTypes.INTEGER);
        //注册返回的结果集
        cs.registerOutParameter(6,oracle.jdbc.OracleTypes.CURSOR);

        cs.execute();
       //注意:getInt(4)中4是由参数的位置决定的
       int rowNum = cs.getInt(4);
       int pageCount = cs.getInt(5);
       int ResultSet rs = (ResultSet)cs.getObject(6);
       System.out.println("rowNum="+rowNum);
       System.out.println("总页数:"+pageCount);
         while(rs.next()){
          System.out.println("编号:"+rs.getInt(1)+"名字"+rs.getString(2));         
}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值