--使用java代码调用这个存储过程
package test;
import java.sql.*;
public class FenYe{
public static void main(String[] args){
try{
//加载数据库驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
//获取数据库连接
Connection conn = DriverManager.getConnection(
"jdbc:oracle:thin:@127.0.0.1:1521:ORCL","scott","tiger");
//创建CallableStatement对象
CallableStatement cs = conn.prepareCall("{call fenye( , , , , , )}");
//给前三个输入参数的?赋值
cs.setString(1,"emp");//要查询的是emp表
cs.setInt(2,5);//每页显示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();
//接收返回的总记录数
int rowNum = cs.getInt(4);
//接收返回的总页数
int pageCount = cs.getInt(5);
//接收返回的结果集
ResultSet rs = (ResultSet)cs.getObject(6);
//打印输出结果
System.out.println("总记录数:" + rowNum);
System.out.println("总页数:" + pageCount);
System.out.println("==========每页显示" +5 + "条===========");
System.out.println("==========当前是第" +1 + "页===========");
int i = 1;
while(rs.next()){
System.out.println("(" + (i++) + ")编号:" + rs.getInt(1) + ",姓名:" + rs.getString(2) + ", 工资:" + rs.getInt(6));
}
}catch(Exception e){
e.printStackTrace();
}
}
}
需要说明的是上面的代码只是为了简单演示一下调用数据库中的分页存储过程,所以对数据库资源的连接和关闭作优化(甚至没有关闭连接,关闭结果集等)。
实际开发中是必须关闭和释放数据库资源的。