在分页时,大家可以把下面的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));
}
}