zoukankan      html  css  js  c++  java
  • 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);
    
            }
        }
  • 相关阅读:
    HDU 5835 Danganronpa(弹丸论破)
    HDU 5813 Elegant Construction(优雅建造)
    HDU 5831 Rikka with Parenthesis II(六花与括号II)
    HDU 5810 Balls and Boxes(盒子与球)
    HDU 5818 Joint Stacks(联合栈)
    Dream Team(最小生成树)
    带权并查集
    HDU 1495 非常可乐(BFS)
    I Hate It(线段树+更新)
    Just a Hook(线段树+区间更新)
  • 原文地址:https://www.cnblogs.com/linbo3168/p/8253076.html
Copyright © 2011-2022 走看看