• 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);
    
            }
        }
  • 相关阅读:
    Java类练习一则
    windows下安装Apache+PHP
    Java 数组/对象练习一则
    windows 安装 apache 报错解决
    延时任务机制
    Javashop电商系统-会员登录方式
    基于canvas商品海报生成源码分享
    uniapp引入微信小程序直播组件
    电商系统中库存的存储于扣减
    电商系统nuxt的中间件代码分享
  • 原文地址:https://www.cnblogs.com/linbo3168/p/8253076.html
Copyright © 2020-2023  润新知