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);
    
            }
        }
  • 相关阅读:
    JVM致命错误日志(hs_err_pid.log)解读
    ant+proguard签名打包 .jar
    ProGuard之——代码混淆
    Java代码加密与反编译(二):用加密算法DES修改classLoader实现对.class文件加密
    利用Ant与Proguard混淆
    Ant在Java项目中的使用(一眼就看会)
    Native2Ascii文件转换 -- 待完善
    scp 的时候提示WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!
    logback与log4j比较
    腾讯、百度、阿里面试经验—(3)阿里面经
  • 原文地址:https://www.cnblogs.com/linbo3168/p/8253076.html
Copyright © 2011-2022 走看看