`

JDBC调用Oracle的存储过程

 
阅读更多

本文主要是总结 如何实现 JDBC调用Oracle的存储过程,从以下情况分别介绍:

  • [1]、只有输入IN参数,没有输出OUT参数
  • [2]、既有输入IN参数,也有输出OUT参数,输出是简单值(非列表)
  • [3]、既有输入IN参数,也有输出OUT参数,输出是列表
  • [4]、输入输出参数是同一个(IN OUT)

【准备工作】

  创建一个测试表TMP_MICHAEL ,并插入数据,SQL如下:

Sql代码  收藏代码
  1. create table TMP_MICHAEL  
  2. (  
  3.   USER_ID    VARCHAR2(20),  
  4.   USER_NAME  VARCHAR2(10),  
  5.   SALARY     NUMBER(8,2),  
  6.   OTHER_INFO VARCHAR2(100)  
  7. )  
  8.   
  9. insert into TMP_MICHAEL (USER_ID, USER_NAME, SALARY, OTHER_INFO)  
  10. values ('michael''Michael', 5000, 'http://sjsky.iteye.com');  
  11. insert into TMP_MICHAEL (USER_ID, USER_NAME, SALARY, OTHER_INFO)  
  12. values ('zhangsan''张三', 10000, null);  
  13. insert into TMP_MICHAEL (USER_ID, USER_NAME, SALARY, OTHER_INFO)  
  14. values ('aoi_sola''苍井空', 99999.99, 'twitter account');  
  15. insert into TMP_MICHAEL (USER_ID, USER_NAME, SALARY, OTHER_INFO)  
  16. values ('李四''李四', 2500, null);  

  Oracle jdbc 常量:

Java代码  收藏代码
  1. private final static String DB_DRIVER = "oracle.jdbc.driver.OracleDriver";  
  2. private final static String DB_CONNECTION = "jdbc:oracle:thin:@127.0.0.1:1521:Ora11g";  
  3. private final static String DB_NAME = "mytest";  
  4. private final static String DB_PWd = "111111";  

 [一]、只有输入IN参数,没有输出OUT参数

 

 

存储过程 TEST_MICHAEL_NOOUT 的相关SQL:

Sql代码  收藏代码
  1. CREATE OR REPLACE PROCEDURE TEST_MICHAEL_NOOUT(P_USERID    IN VARCHAR2,  
  2.                                                P_USERNAME  IN VARCHAR2,  
  3.                                                P_SALARY    IN NUMBER,  
  4.                                                P_OTHERINFO IN VARCHAR2) IS  
  5. BEGIN  
  6.   
  7.   INSERT INTO TMP_MICHAEL  
  8.     (USER_ID, USER_NAME, SALARY, OTHER_INFO)  
  9.   VALUES  
  10.     (P_USERID, P_USERNAME, P_SALARY, P_OTHERINFO);  
  11.   
  12. END TEST_MICHAEL_NOOUT;  

调用代码如下:

Java代码  收藏代码
  1. /** 
  2.     * 测试调用存储过程:无返回值 
  3.     * @blog http://sjsky.iteye.com 
  4.     * @author Michael 
  5.     * @throws Exception 
  6.     */  
  7.    public static void testProcNoOut() throws Exception {  
  8.        System.out.println("-------  start 测试调用存储过程:无返回值");  
  9.        Connection conn = null;  
  10.        CallableStatement callStmt = null;  
  11.        try {  
  12.            Class.forName(DB_DRIVER);  
  13.            conn = DriverManager.getConnection(DB_CONNECTION, DB_NAME, DB_PWd);  
  14.            // 存储过程 TEST_MICHAEL_NOOUT 其实是向数据库插入一条数据  
  15.            callStmt = conn.prepareCall("{call TEST_MICHAEL_NOOUT(?,?,?,?)}");  
  16.   
  17.            // 参数index从1开始,依次 1,2,3...  
  18.            callStmt.setString(1"jdbc");  
  19.            callStmt.setString(2"JDBC");  
  20.            callStmt.setDouble(38000.00);  
  21.            callStmt.setString(4"http://sjsky.iteye.com");  
  22.            callStmt.execute();  
  23.            System.out.println("-------  Test End.");  
  24.        } catch (Exception e) {  
  25.            e.printStackTrace(System.out);  
  26.        } finally {  
  27.            if (null != callStmt) {  
  28.                callStmt.close();  
  29.            }  
  30.            if (null != conn) {  
  31.                conn.close();  
  32.            }  
  33.        }  
  34.    }  

 运行后查询数据库内容,已经成功插入数据,截图如下:


 

[二]、既有输入IN参数,也有输出OUT参数,输出是简单值(非列表)

 

存储过程 TEST_MICHAEL 的SQL如下:

Sql代码  收藏代码
  1. CREATE OR REPLACE PROCEDURE TEST_MICHAEL(P_USERID IN VARCHAR2,  
  2.                                          P_SALARY IN NUMBER,  
  3.                                          P_COUNT  OUT NUMBER) IS  
  4.   V_SALARY NUMBER := P_SALARY;  
  5. BEGIN  
  6.   IF V_SALARY IS NULL THEN  
  7.     V_SALARY := 0;  
  8.   END IF;  
  9.   IF P_USERID IS NULL THEN  
  10.     SELECT COUNT(*)  
  11.       INTO P_COUNT  
  12.       FROM TMP_MICHAEL T  
  13.      WHERE T.SALARY >= V_SALARY;  
  14.   ELSE  
  15.     SELECT COUNT(*)  
  16.       INTO P_COUNT  
  17.       FROM TMP_MICHAEL T  
  18.      WHERE T.SALARY >= V_SALARY  
  19.        AND T.USER_ID LIKE '%' || P_USERID || '%';  
  20.   END IF;  
  21.   DBMS_OUTPUT.PUT_LINE('v_count=:' || P_COUNT);  
  22. END TEST_MICHAEL;  

  调用程序如下:

Java代码  收藏代码
  1. /** 
  2.     * 测试调用存储过程:返回值是简单值非列表 
  3.     * @blog http://sjsky.iteye.com 
  4.     * @author Michael 
  5.     * @throws Exception 
  6.     */  
  7.    public static void testProcOutSimple() throws Exception {  
  8.        System.out.println("-------  start 测试调用存储过程:返回值是简单值非列表");  
  9.        Connection conn = null;  
  10.        CallableStatement stmt = null;  
  11.        try {  
  12.            Class.forName(DB_DRIVER);  
  13.            conn = DriverManager.getConnection(DB_CONNECTION, DB_NAME, DB_PWd);  
  14.   
  15.            stmt = conn.prepareCall("{call TEST_MICHAEL(?,?,?)}");  
  16.   
  17.            stmt.setString(1"");  
  18.            stmt.setDouble(23000);  
  19.   
  20.            // out 注册的index 和取值时要对应  
  21.            stmt.registerOutParameter(3, Types.INTEGER);  
  22.            stmt.execute();  
  23.   
  24.            // getXxx(index)中的index 需要和上面registerOutParameter的index对应  
  25.            int i = stmt.getInt(3);  
  26.            System.out.println("符号条件的查询结果 count := " + i);  
  27.            System.out.println("-------  Test End.");  
  28.        } catch (Exception e) {  
  29.            e.printStackTrace(System.out);  
  30.        } finally {  
  31.            if (null != stmt) {  
  32.                stmt.close();  
  33.            }  
  34.            if (null != conn) {  
  35.                conn.close();  
  36.            }  
  37.        }  
  38.    }  

   测试程序就是查询薪水3000以上人员的数量 ,运行结果如下:

------- start 测试调用存储过程:返回值是简单值非列表
符号条件的查询结果 count := 4
------- Test End.

 

[三]、既有输入IN参数,也有输出OUT参数,输出是列表

  首先需要创建PACKAGE TEST_PKG_CURSOR 的SQL如下:

Sql代码  收藏代码
  1. CREATE OR REPLACE PACKAGE TEST_PKG_CURSOR IS  
  2.   
  3.   -- Author  : MICHAEL  http://sjsky.iteye.com  
  4.   TYPE TEST_CURSOR IS REF CURSOR;  
  5.   
  6. END TEST_PKG_CURSOR;  

再创建存储过程 TEST_P_OUTRS 的SQL如下:

Sql代码  收藏代码
  1. CREATE OR REPLACE PROCEDURE TEST_P_OUTRS(P_SALARY IN NUMBER,  
  2.                                          P_OUTRS  OUT TEST_PKG_CURSOR.TEST_CURSOR) IS  
  3.   V_SALARY NUMBER := P_SALARY;  
  4. BEGIN  
  5.   IF P_SALARY IS NULL THEN  
  6.     V_SALARY := 0;  
  7.   END IF;  
  8.   OPEN P_OUTRS FOR  
  9.     SELECT * FROM TMP_MICHAEL T WHERE T.SALARY > V_SALARY;  
  10. END TEST_P_OUTRS;  

 调用存储过程的代码如下:

Java代码  收藏代码
  1. /** 
  2.     * 测试调用存储过程:有返回值且返回值为列表的 
  3.     * @blog http://sjsky.iteye.com 
  4.     * @author Michael 
  5.     * @throws Exception 
  6.     */  
  7.    public static void testProcOutRs() throws Exception {  
  8.        System.out.println("-------  start 测试调用存储过程:有返回值且返回值为列表的");  
  9.        Connection conn = null;  
  10.        CallableStatement stmt = null;  
  11.        ResultSet rs = null;  
  12.        try {  
  13.            Class.forName(DB_DRIVER);  
  14.            conn = DriverManager.getConnection(DB_CONNECTION, DB_NAME, DB_PWd);  
  15.   
  16.            stmt = conn.prepareCall("{call TEST_P_OUTRS(?,?)}");  
  17.   
  18.            stmt.setDouble(13000);  
  19.            stmt.registerOutParameter(2, OracleTypes.CURSOR);  
  20.            stmt.execute();  
  21.   
  22.            // getXxx(index)中的index 需要和上面registerOutParameter的index对应  
  23.            rs = (ResultSet) stmt.getObject(2);  
  24.            // 获取列名及类型  
  25.            int colunmCount = rs.getMetaData().getColumnCount();  
  26.            String[] colNameArr = new String[colunmCount];  
  27.            String[] colTypeArr = new String[colunmCount];  
  28.            for (int i = 0; i < colunmCount; i++) {  
  29.                colNameArr[i] = rs.getMetaData().getColumnName(i + 1);  
  30.                colTypeArr[i] = rs.getMetaData().getColumnTypeName(i + 1);  
  31.                System.out.print(colNameArr[i] + "(" + colTypeArr[i] + ")"  
  32.                        + " | ");  
  33.            }  
  34.            System.out.println();  
  35.            while (rs.next()) {  
  36.                StringBuffer sb = new StringBuffer();  
  37.                for (int i = 0; i < colunmCount; i++) {  
  38.                    sb.append(rs.getString(i + 1) + " | ");  
  39.                }  
  40.                System.out.println(sb);  
  41.            }  
  42.            System.out.println("------- Test Proc Out is ResultSet end. ");  
  43.   
  44.        } catch (Exception e) {  
  45.            e.printStackTrace(System.out);  
  46.        } finally {  
  47.            if (null != rs) {  
  48.                rs.close();  
  49.            }  
  50.            if (null != stmt) {  
  51.                stmt.close();  
  52.            }  
  53.            if (null != conn) {  
  54.                conn.close();  
  55.            }  
  56.        }  
  57.    }  

 运行结果如下:

------- start 测试调用存储过程:有返回值且返回值为列表的
USER_ID(VARCHAR2) | USER_NAME(VARCHAR2) | SALARY(NUMBER) | OTHER_INFO(VARCHAR2) | 
michael | Michael | 5000 | null | 
zhangsan | 张三 | 10000 | null | 
aoi_sola | 苍井空 | 99999.99 | null | 
jdbc | JDBC | 8000 | http://sjsky.iteye.com | 
------- Test Proc Out is ResultSet end.
 

[四]、输入输出参数是同一个(IN OUT)

 

创建存储过程TEST_P_INOUT 的SQL如下:

Sql代码  收藏代码
  1. CREATE OR REPLACE PROCEDURE TEST_P_INOUT(P_USERID IN VARCHAR2,  
  2.                                          P_NUM    IN OUT NUMBER) IS  
  3.   V_COUNT  NUMBER;  
  4.   V_SALARY NUMBER := P_NUM;  
  5. BEGIN  
  6.   IF V_SALARY IS NULL THEN  
  7.     V_SALARY := 0;  
  8.   END IF;  
  9.   
  10.   SELECT COUNT(*)  
  11.     INTO V_COUNT  
  12.     FROM TMP_MICHAEL  
  13.    WHERE USER_ID LIKE '%' || P_USERID || '%'  
  14.      AND SALARY >= V_SALARY;  
  15.   P_NUM := V_COUNT;  
  16. END TEST_P_INOUT;  

 调用存储过程的代码:

Java代码  收藏代码
  1. /** 
  2.      * 测试调用存储过程: INOUT同一个参数: 
  3.      * @blog http://sjsky.iteye.com 
  4.      * @author Michael 
  5.      * @throws Exception 
  6.      */  
  7.     public static void testProcInOut() throws Exception {  
  8.         System.out.println("-------  start 测试调用存储过程:INOUT同一个参数");  
  9.         Connection conn = null;  
  10.         CallableStatement stmt = null;  
  11.         try {  
  12.             Class.forName(DB_DRIVER);  
  13.             conn = DriverManager.getConnection(DB_CONNECTION, DB_NAME, DB_PWd);  
  14.   
  15.             stmt = conn.prepareCall("{call TEST_P_INOUT(?,?)}");  
  16.   
  17.             stmt.setString(1"michael");  
  18.             stmt.setDouble(23000);  
  19.   
  20.             // 注意此次注册out 的index 和上面的in 参数index 相同  
  21.             stmt.registerOutParameter(2, Types.INTEGER);  
  22.             stmt.execute();  
  23.   
  24.             // getXxx(index)中的index 需要和上面registerOutParameter的index对应  
  25.             int count = stmt.getInt(2);  
  26.             System.out.println("符号条件的查询结果 count := " + count);  
  27.             System.out.println("-------  Test End.");  
  28.         } catch (Exception e) {  
  29.             e.printStackTrace(System.out);  
  30.         } finally {  
  31.             if (null != stmt) {  
  32.                 stmt.close();  
  33.             }  
  34.             if (null != conn) {  
  35.                 conn.close();  
  36.             }  
  37.         }  
  38.     }  

 运行结果如下:

------- start 测试调用存储过程:INOUT同一个参数
符号条件的查询结果 count := 1
------- Test End.

 

到处基本介绍已经结束了,希望能给大家有所帮助。

 

 

本文连接:http://sjsky.iteye.com/blog/1246657

 

 

转载请注明来自:Michael's blog @ http://sjsky.iteye.com


分享到:
评论

相关推荐

    Spring JdbcTemplate调用Oracle存储过程实现CRUD

    使用 Spring JdbcTemplate 调用 Oracle 存储过程实现 CRUD 在本文中,我们将讨论如何使用 Spring JdbcTemplate 调用 Oracle 存储过程来实现 CRUD(Create、Read、Update、Delete)操作。我们将首先编写 Oracle 存储...

    JDBC调用oracle存储过程.docx

    在本场景中,我们讨论的是如何使用JDBC调用Oracle数据库中的存储过程。存储过程是一组预先编译的SQL语句,可以提高数据库操作的效率和安全性。 首先,我们需要了解如何创建Oracle存储过程。在示例中,我们看到了三...

    JDBC与Oracle存储过程

    JDBC调用Oracle存储过程** 调用Oracle存储过程通常使用`CallableStatement`。步骤如下: 1. **准备CallableStatement**:通过`Connection.prepareCall()`创建CallableStatement,传入调用存储过程的SQL格式字符串...

    java调用oracle存储过程返回结果集,Record,cursor参照.pdf

    3. Java调用Oracle存储过程:Java程序可以通过JDBC来调用Oracle存储过程,获取结果集。 4. Type类型:Type类型是Oracle中的一种数据类型,用于定义复杂数据结构。 5. PACKAGE和PROCEDURE:PACKAGE和PROCEDURE是...

    java调用oracle存储过程入门实例 增删改查

    总结来说,这个入门实例涵盖了使用Java通过JDBC调用Oracle存储过程进行CRUD操作的基本流程,以及利用DOM4J解析XML配置文件和`ThreadLocal`管理数据库连接的方法。这样的设计使得程序更加模块化,易于维护,同时也...

    springboot整合mybatis调用oracle存储过程

    本文将深入探讨如何在Spring Boot项目中整合MyBatis,实现调用Oracle存储过程并处理游标返回的数据。 首先,我们需要在Spring Boot项目中引入相关的依赖。在`pom.xml`文件中添加Oracle JDBC驱动(ojdbc66-oracle...

    润乾报表调用oracle存储过程案例说明

    在实际的业务场景中,有时我们需要调用数据库中的存储过程来获取或处理数据,本篇将详细介绍如何在润乾报表中调用Oracle存储过程。 首先,我们要在Oracle数据库中创建存储过程。以下是一个简单的存储过程示例,名为...

    jdbc调用存储过程实现增删改查

    以上就是使用JDBC调用Oracle存储过程进行增删改查的基本步骤和概念。实际应用中,可能需要处理异常、优化性能,以及根据具体需求调整代码结构。在开发时,确保遵循最佳实践,如使用连接池、预编译的...

    Java调用oracle存储过程通过游标返回临时表

    本篇文章将深入探讨如何使用Java调用Oracle存储过程,并通过游标获取存储过程中返回的临时表数据。 首先,Oracle存储过程是一种在数据库端执行的预编译SQL语句和PL/SQL代码集合。它可以接收参数、执行业务逻辑并...

    java调用oracle存储过程或者函数

    以上就是Java调用Oracle存储过程或函数的主要知识点,实践中要根据具体情况进行适当的调整和优化。在处理过程中,参考Oracle的JDBC文档和官方示例,以及Java API文档,将有助于理解和解决问题。

    oracle存储过程学习经典入门

    用 Java 调用 Oracle 存储过程时,需要使用 JDBC 驱动程序来连接 Oracle 数据库,然后使用 CallableStatement 对象来调用存储过程。 在存储过程中做简单动态查询 在存储过程中,做简单动态查询需要使用 EXECUTE ...

    jdbc连接oracle,执行存储过程,带数据库存储过程

    执行Oracle存储过程主要涉及以下几个关键点: 1. 创建CallableStatement对象:使用Connection对象的`prepareCall()`方法创建CallableStatement实例,例如`CallableStatement cs = conn.prepareCall("{call procedure...

    用JDBC操作Oracle的存储过程返回值

    本篇将深入探讨如何使用JDBC来调用Oracle的存储过程并处理返回值。 首先,了解存储过程的概念。存储过程是预编译的SQL语句集合,它们存储在数据库服务器中,可以接受参数,执行一系列操作,并可能返回结果。在...

    java调用Oracle存储过程的代码

    总结,通过Java调用Oracle存储过程,我们需要配置JDBC驱动,建立数据库连接,创建CallableStatement,设置参数,执行存储过程,并处理返回的结果。在这个例子中,我们展示了如何调用一个简单的存储过程并打印返回的...

    ibatis调用oracle存储过程

    在IT领域,特别是数据库操作与Java开发中,利用ibatis框架调用Oracle存储过程是一个常见的需求,这不仅能够提升代码的执行效率,还能增强应用程序的安全性。本文将深入解析ibatis如何与Oracle数据库中的存储过程进行...

    用java调用oracle存储过程

    以上代码展示了如何在Java中调用Oracle数据库的三种类型的存储过程:无返回值的存储过程、有单个返回值的存储过程以及返回列表的存储过程。对于无返回值的存储过程,主要涉及的是参数的输入,通过`execute()`方法...

    Jsp中调用Oracle存储过程的小例子

    本示例展示了如何在JSP中调用Oracle存储过程。 首先,我们创建一个名为`p_test2`的Oracle存储过程。这个过程接收一个数值型参数`i`,并在表`t`中插入一行数据。存储过程的定义如下: ```sql CREATE OR REPLACE ...

    Java调用Oracle存储过程

    本文主要探讨如何在Java中调用Oracle存储过程,以及如何通过Java创建Oracle存储过程。 首先,我们来看如何在Java中调用不带输出参数的Oracle存储过程。在给定的例子中,有一个名为`pro1`的存储过程,它接受一个整数...

    oracle存储过程(语法实例).pdf

    Java可以通过JDBC调用Oracle存储过程,包括`CallableStatement`对象来执行过程并处理输入/输出参数。 9. **更新与权限保留** 使用`CREATE OR REPLACE PROCEDURE`语句更新存储过程时,原有执行权限不会丢失。 10....

Global site tag (gtag.js) - Google Analytics