您的位置:首页 > 数据库

利用pl/sql过程编写分页

2009-10-02 09:35 357 查看
在分页时,大家可以把下面的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));
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: