`
wonderful1935
  • 浏览: 2713 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类
最新评论

JDBC调用oracle存储过程

阅读更多
--声明包
create or replace package p_base
as
Type p_cur is ref cursor;
end p_base;

--游标类型
create or replace procedure test(cur out p_base.p_cur) as
begin
  open cur for
    select t.deptno, t.dname, t.loc From dept t;
end test;

--基本类型
create or replace procedure obtaindeptnames(p_dname out varchar2) as
begin
  select dname into p_dname from dept t where t.deptno = 10;
end;



//数据连接类DatabaseConnection.java
package invokeprocedure;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DatabaseConnection
{
    private Connection conn;
    
    public Connection getConnection()
    {
        String username = "scott";
        String password = "tiger";
        String url = "jdbc:oracle:thin:@10.40.71.13:1521:mdsp";
        try
        {
            Class.forName("oracle.jdbc.driver.OracleDriver");
            conn = DriverManager.getConnection(url, username, password);
        }
        catch (ClassNotFoundException e)
        {
            e.printStackTrace();
        }
        catch (SQLException e)
        {
            e.printStackTrace();
        }
        return conn;
    }
    
    public static void main(String[] args)
    {
        Connection conn1 = new DatabaseConnection().getConnection();
        System.out.print(conn1);
    }
}
//JavaBean:DepartmentInfo.java
package invokeprocedure;

public class DepartmentInfo
{
    private int deptno;
    private String deptname;
    private String loc;
    
    public int getDeptno()
    {
        return deptno;
    }
    
    public void setDeptno(int deptno)
    {
        this.deptno = deptno;
    }
    
    public String getDeptname()
    {
        return deptname;
    }
    
    public void setDeptname(String deptname)
    {
        this.deptname = deptname;
    }
    
    public String getLoc()
    {
        return loc;
    }
    
    public void setLoc(String loc)
    {
        this.loc = loc;
    }
}
//调用 QueryWithProcedure.java
package invokeprocedure;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import oracle.jdbc.OracleTypes;

public class QueryWithProcedure
{
    private Connection con;
    
    private CallableStatement cs;
    
    private ResultSet rs;
    
    private void getConn()
    {
        con = new DatabaseConnection().getConnection();
    }
    
    public List<DepartmentInfo> getResults()
    {
        getConn();
        List<DepartmentInfo> list = new ArrayList<DepartmentInfo>();
        try
        {
            cs = con.prepareCall("{call test(?)}");
            cs.registerOutParameter(1, OracleTypes.CURSOR);
            boolean ifsuccess = cs.execute();
            if (!ifsuccess)
            {
                rs = (ResultSet)cs.getObject(1);
                while (rs.next())
                {
                    DepartmentInfo dept = new DepartmentInfo();
                    dept.setDeptno(rs.getInt(1));
                    dept.setDeptname(rs.getString(2));
                    dept.setLoc(rs.getString(3));
                    list.add(dept);
                }
                return list;
            }
            else
            {
                System.out.print("execute procedure failed!");
                return list;
            }
        }
        catch (SQLException e)
        {
            e.printStackTrace();
            return list;
        }
        finally
        {
            try
            {
                rs = null;
                if (cs != null)
                    cs.close();
                if (con != null)
                    con.close();
            }
            catch (SQLException e)
            {
                e.printStackTrace();
            }
        }
    }
    
    public List<String> getDeptNames()
    {
        getConn();
        List<String> list = new ArrayList<String>();
        try
        {
            cs = con.prepareCall("{call obtaindeptnames(?)}");
            cs.registerOutParameter(1, oracle.jdbc.OracleTypes.VARCHAR);
            boolean ifsuccess = cs.execute();
            if (!ifsuccess)
            {
                String str = (String)cs.getObject(1);
                list.add(str);
                return list;
            }
            else
            {
                System.out.print("execute procedure failed!");
                return list;
            }
        }
        catch (SQLException e)
        {
            e.printStackTrace();
            return list;
        }
        catch (Exception e)
        {
            e.printStackTrace();
            return null;
        }
        finally
        {
            try
            {
                rs = null;
                if (cs != null)
                    cs.close();
                if (con != null)
                    con.close();
            }
            catch (SQLException e)
            {
                e.printStackTrace();
            }
        }
    }
    
    public static void main(String[] arg)
    {
        testGetResult();
    }
    
    private static void testGetResult()
    {
        List<DepartmentInfo> list1 = new QueryWithProcedure().getResults();
        for (DepartmentInfo di : list1)
        {
            System.out.print(di.getDeptno() + "-->" + di.getDeptname() + "-->" + di.getLoc());
        }
    }
    
    @SuppressWarnings("unused")
    private static void testGetDeptNames()
    {
        List<String> list2 = new QueryWithProcedure().getDeptNames();
        for (String str : list2)
        {
            System.out.print(str);
        }
    }
}





分享到:
评论

相关推荐

    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存储过程入门实例 增删改查

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

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

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

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

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

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

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

    springboot整合mybatis调用oracle存储过程

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

    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()`方法...

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

    在Java编程中,调用Oracle数据库的存储...总之,通过Java调用Oracle存储过程,我们可以有效地执行数据库操作,同时利用存储过程带来的性能和安全优势。了解如何正确设置参数、执行和处理结果是成功实现这一目标的关键。

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

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

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

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

Global site tag (gtag.js) - Google Analytics