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);

        }
    }
原文地址:https://www.cnblogs.com/linbo3168/p/8253076.html