java 调用 oracle的function 和 procedure
1.调用函数
CallableStatement cs=con.prepareCall("{?=call get_pname(?,?,?)}");
第一个?表示返回的值,后面的?可以是输入参数,也可以是输出参数。
第一个?是返回参数,所以必须有语句:
connection.registerOutParameter(1, Types.VARCHAR);(Types.varchar是类型)
后面的?如果是输出参数,应该也加上registerOutParameter语句:
connection.registerOutParameter(2, Types.VARCHAR);(2是第2个占位符,Types.varchar是类型)
最后打印输出的结果:
System.out.println(cs.getString(1)); (1是对应输出参数,第一个输出参数)
2.调用存储过程
CallableStatement cs=con.prepareCall("{call stu_pro(?,?,?)}");(与函数的区别是:没有?=)
java程序中要打印调用过程获得的值,需调用有输出参数的存储过程,用法和调用函数一样。
public void getDealmainNo() { try { conn = C3P0XmlSimplify.getInstance().getConnection(); /* ?=call getDealmainNo(?,?); * 第一个问号(?) 代表输入值,但要制定输入类型:callableStatement.registerOutParameter(1, Types.VARCHAR); * 第二个问号(?) 代表输入值,通过callableStatement.setString()方法类制定入参的类型 ; * 。。。。。。。 * */ callableStatement = conn.prepareCall("{?=call getDealmainNo(?,?)}"); callableStatement.registerOutParameter(1, Types.VARCHAR); callableStatement.setString(2, "2018-01-09"); callableStatement.setString(3, "IBO"); callableStatement.execute(); String string = callableStatement.getString(1); System.out.println(string); } catch (Exception e) { e.printStackTrace(); }finally { C3P0XmlSimplify.releaseSources(conn); } }