利用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));
}
}
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));
}
}
相关文章推荐
- PL/SQL的进阶----编写分页过程
- oracle pl/sql的进价、编写分页过程
- PL/SQL中编写Oracle数据库分页的存储过程
- Oracle学习笔记(二十九)——pl/sql的进阶之编写分页过程
- PL/SQL中编写Oracle数据库分页的存储过程
- pl/sql 编写 Oracle分页的存储过程 Java调用该过程
- oracle(6)pl/sql的进价 编写分页过程
- oralce实战第七天--pl/sql的进阶、分页存储过程、例外和视图
- 修改后的SQL分页存储过程,利用2分法,支持排序
- 利用SQL未公开的存储过程实现分页
- SQL:利用存储过程实现分页
- 修改后的SQL分页存储过程,利用2分法,支持排序
- PL/SQL开发中动态SQL的使用与过程分页
- [oracle]pl/sql --分页过程demo
- PL/SQL中编写Oracle数据库分页的存储过程
- Oracle基础(五)pl/sql进阶(分页过程)
- 修改后的SQL分页存储过程,利用2分法,支持排序
- [oracle]pl/sql --分页过程demo
- 利用SQL的游标存储过程分页
- 利用SQL隐藏的存储过程分页