zoukankan      html  css  js  c++  java
  • Java -- JDBC 学习--调用函数&存储过程

    调用函数&存储过程

    /**
         * 如何使用 JDBC 调用存储在数据库中的函数或存储过程
         */
        @Test
        public void testCallableStatment() {
    
            Connection connection = null;
            CallableStatement callableStatement = null;
    
            try {
                connection = JDBCTools.getConnection();
    
                // 1. 通过 Connection 对象的 prepareCall()
                // 方法创建一个 CallableStatement 对象的实例.
                // 在使用 Connection 对象的 preparedCall() 方法时,
                // 需要传入一个 String 类型的字符串, 该字符串用于指明如何调用存储过程.
                String sql = "{?= call sum_salary(?, ?)}";
                callableStatement = connection.prepareCall(sql);
    
                // 2. 通过 CallableStatement 对象的 
                //reisterOutParameter() 方法注册 OUT 参数.
                callableStatement.registerOutParameter(1, Types.NUMERIC);
                callableStatement.registerOutParameter(3, Types.NUMERIC);
                
                // 3. 通过 CallableStatement 对象的 setXxx() 方法设定 IN 或 IN OUT 参数. 若想将参数默认值设为
                // null, 可以使用 setNull() 方法.
                callableStatement.setInt(2, 80);
                
                // 4. 通过 CallableStatement 对象的 execute() 方法执行存储过程
                callableStatement.execute();
                
                // 5. 如果所调用的是带返回参数的存储过程, 
                //还需要通过 CallableStatement 对象的 getXxx() 方法获取其返回值.
                double sumSalary = callableStatement.getDouble(1);
                long empCount = callableStatement.getLong(3);
                
                System.out.println(sumSalary);
                System.out.println(empCount);
                
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                JDBCTools.releaseDB(null, callableStatement, connection);
            }
    
    
        }
  • 相关阅读:
    Java设置环境变量
    php 生成二维码
    php 生成读取csv文件并解决中文乱码
    php 过滤重复的数组
    php 读取,生成excel文件
    php 逐行读取文本文件
    php 多维数组按键值分类
    python学习,day2:利用列表做购物车实例
    python学习,day1作业:设计一个三级菜单
    python学习,day2:字典
  • 原文地址:https://www.cnblogs.com/androidsuperman/p/7020724.html
Copyright © 2011-2022 走看看