zoukankan      html  css  js  c++  java
  • JAVA中调用存储过程和函数

    参考网址:http://www.exampledepot.com/egs/java.sql/CallProcedure.html

    Calling a Stored Procedure in a Database

    This example demonstrates how to call stored procedures with IN, OUT, and IN/OUT parameters.
    CallableStatement cs;
    try {
      // Call a procedure with no parameters
        cs = connection.prepareCall("{call myproc}");
        cs.execute();
    
      // Call a procedure with one IN parameter
        cs = connection.prepareCall("{call myprocin(?)}");
    
        // Set the value for the IN parameter
        cs.setString(1, "a string");
    
        // Execute the stored procedure
        cs.execute();
    
      // Call a procedure with one OUT parameter
        cs = connection.prepareCall("{call myprocout(?)}");
    
        // Register the type of the OUT parameter
        cs.registerOutParameter(1, Types.VARCHAR);
    
        // Execute the stored procedure and retrieve the OUT value
        cs.execute();
        String outParam = cs.getString(1);     // OUT parameter
    
      // Call a procedure with one IN/OUT parameter
        cs = connection.prepareCall("{call myprocinout(?)}");
    
        // Register the type of the IN/OUT parameter
        cs.registerOutParameter(1, Types.VARCHAR);
    
        // Set the value for the IN/OUT parameter
        cs.setString(1, "a string");
    
        // Execute the stored procedure and retrieve the IN/OUT value
        cs.execute();
        outParam = cs.getString(1);            // OUT parameter
    } catch (SQLException e) {
    }

    参考网址:http://www.exampledepot.com/egs/java.sql/CallFunction.html

    Calling a Function in a Database

    A function is essentially a stored procedure that returns a result. This example demonstrates how to call functions with IN, OUT, and IN/OUT parameters.
    CallableStatement cs;
    try {
      // Call a function with no parameters; the function returns a VARCHAR
        // Prepare the callable statement
        cs = connection.prepareCall("{? = call myfunc}");
    
        // Register the type of the return value
        cs.registerOutParameter(1, i);
    
        // Execute and retrieve the returned value
        cs.execute();
        String retValue = cs.getString(1);
    
      // Call a function with one IN parameter; the function returns a VARCHAR
        cs = connection.prepareCall("{? = call myfuncin(?)}");
    
        // Register the type of the return value
        cs.registerOutParameter(1, Types.VARCHAR);
    
        // Set the value for the IN parameter
        cs.setString(2, "a string");
    
        // Execute and retrieve the returned value
        cs.execute();
        retValue = cs.getString(1);
    
      // Call a function with one OUT parameter; the function returns a VARCHAR
        cs = connection.prepareCall("{? = call myfuncout(?)}");
    
        // Register the types of the return value and OUT parameter
        cs.registerOutParameter(1, Types.VARCHAR);
        cs.registerOutParameter(2, Types.VARCHAR);
    
        // Execute and retrieve the returned values
        cs.execute();
        retValue = cs.getString(1);           // return value
        String outParam = cs.getString(2);    // OUT parameter
    
      // Call a function with one IN/OUT parameter; the function returns a VARCHAR
        cs = connection.prepareCall("{? = call myfuncinout(?)}");
    
        // Register the types of the return value and OUT parameter
        cs.registerOutParameter(1, Types.VARCHAR);
        cs.registerOutParameter(2, Types.VARCHAR);
    
        // Set the value for the IN/OUT parameter
        cs.setString(2, "a string");
    
        // Execute and retrieve the returned values
        cs.execute();
        retValue = cs.getString(1);           // return value
        outParam = cs.getString(2);           // IN/OUT parameter
    } catch (SQLException e) {
    }

    CALL CURSOR:

    For Oracle stored procedure returns CURSOR parameter, you can

    1、Registered via JDBC CallableStatement.registerOutParameter(index,OracleTypes.CURSOR).

    2、Get it back via callableStatement.getObject(index).

    CODE:

     1 //getDBUSERCursor is a stored procedure
     2 String getDBUSERCursorSql = "{call getDBUSERCursor(?,?)}";
     3 callableStatement = dbConnection.prepareCall(getDBUSERCursorSql);
     4 callableStatement.setString(1, "mkyong");
     5 callableStatement.registerOutParameter(2, OracleTypes.CURSOR);
     6  
     7 // execute getDBUSERCursor store procedure
     8 callableStatement.executeUpdate();
     9  
    10 // get cursor and cast it to ResultSet
    11 rs = (ResultSet) callableStatement.getObject(2);
    12  
    13 // loop it like normal
    14 while (rs.next()) {
    15     String userid = rs.getString("USER_ID");
    16     String userName = rs.getString("USERNAME");
    17 }

     

  • 相关阅读:
    AVL自平衡二叉树
    笔试+面试信息整理----面向笔试学习、面向面经编程
    传入值参数&传入引用参数的区别
    NLPIR智能挖掘实现行业大数据应用价值
    NLPIR大数据挖掘融合库、智、理三大先进理论技术
    NLPIR智能语义挖掘文本大数据深层意义
    NLPIR智能语义技术从采集到分析一步到位
    灵玖软件:NLPIR智能挖掘对文本数据精细化分析
    九眼合同智能审核系统运用NLPIR大数据技术进行核查
    NLPIR九眼智能审核平台助合同文本深度核查
  • 原文地址:https://www.cnblogs.com/caroline/p/2450181.html
Copyright © 2011-2022 走看看