oracle 存储过程中只有输出参数,想用JAVA调用,怎么能取到输出参数值,请给出一个简单实例,谢谢

2025-01-05 09:48:21
推荐回答(2个)
回答1:

import java.sql.*;

public class ProcedureWithArgs {
public static void main(String args[]) throws Exception {
// 加载Oracle驱动
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
// 获得Oracle数据库连接
Connection conn = DriverManager.getConnection(
"jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL", sUsr, sPwd);
// 创建Oracle存储过程的对象,调用存储过程
CallableStatement c = conn.divpareCall("{call pro2(?,?)}");
// 给Oracle存储过程的参数设置值 ,将第一个参数的值设置成188
c.setInt(1, 188);
// 注册存储过程的第二个参数
c.registerOutParameter(2, java.sql.Types.INTEGER);
// 执行Oracle存储过程
c.execute();
// 得到存储过程的输出参数值并打印出来
System.out.println(c.getInt(2));
conn.close();
}
}

回答2:

Connection conn;
//...
CallableStatement cs = conn.prepareCall("{call proname(?)}");
cs.registerOutParameter(1, Types.CHAR); //将第1个参数设为输出,类型为char
cs.execute();
String result = cs.getString(1); //保存结果