全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java调用Oracle存储过程详解

Java调用Oracle存储过程详解

步骤:

1、编写Oracle存储过程

2、编写数据库获取连接工具类

3、编写简单应用调用存储过程

实现:

1、Oracle存储过程:

/*测试表*/
create table test(
  id varchar2(32),
  name varchar2(32)
);

/*存储过程 插入数据*/  
CREATE OR REPLACE PROCEDURE insert_procedure(
  PARA1 IN VARCHAR2,
  PARA2 IN VARCHAR2
) AS
BEGIN
 INSERT INTO test (id, name) VALUES (PARA1, PARA2);
END insert_procedure;

/*存储过程 返回结果集*/
CREATE OR REPLACE PROCEDURE select_procedure(
  para_id IN VARCHAR2,
  name OUT sys_refcursor /* 这个sys_refcursor类型在SYS.STANDARD包中 */
) AS
BEGIN
 OPEN name FOR
  SELECT * FROM test WHERE id = para_id;
END;

2、JDBC工具类

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

public class DBUtil {
  public static final String DRIVER = "oracle.jdbc.driver.OracleDriver";
  public static final String URL = "jdbc:oracle:thin:@localhost:1521/orcl";
  public static final String USERNAME = "pfm";
  public static final String PASSWORD = "pfm";

  /**
   * 通过静态代码块 注册数据库驱动
   */
  static {
    try {
      Class.forName(DRIVER);
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    }
  }

  /**
   * 获得Connection
   * 
   * @return
   */
  public static Connection getConnection() {
    Connection conn = null;
    try {
      conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return conn;
  }

  /**
   * 获得Statement
   * 
   * @return
   */
  public static Statement getStatement() {
    Statement st = null;
    try {
      st = getConnection().createStatement();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return st;
  }

  /**
   * 关闭ResultSet
   * 
   * @param rs
   */
  public static void closeResultSet(ResultSet rs) {
    if (rs != null) {
      try {
        rs.close();
      } catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }

  /**
   * 关闭Statement
   * 
   * @param st
   */
  public static void closeStatement(Statement st) {
    if (st != null) {
      try {
        st.close();
      } catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }

  /**
   * 关闭Connection
   * 
   * @param conn
   */
  public static void closeConnection(Connection conn) {
    if (conn != null) {
      try {
        conn.close();
      } catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }

  /**
   * 关闭全部
   * 
   * @param rs
   * @param sta
   * @param conn
   */
  public static void closeAll(ResultSet rs, Statement sta, Connection conn) {
    closeResultSet(rs);
    closeStatement(sta);
    closeConnection(conn);
  }

}

3、调用存储过程:

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import oracle.jdbc.driver.OracleTypes;

/**
 * 测试调用存储过程
 * 
 */
public class StoredTest {
  public static void main(String[] args) {
    insert_call();
    //select_call();
  }

  /**
   * 执行存储过程 插入数据
   */
  public static void insert_call() {
    Connection conn = DBUtil.getConnection();
    PreparedStatement pst = null;

    CallableStatement proc = null; // 创建执行存储过程的对象
    try {
      proc = conn.prepareCall("{ call insert_procedure(?,?) }");
      proc.setString(1, "1"); // 设置第一个输入参数
      proc.setString(2, "hello call"); // 设置第一个输入参数
      proc.execute();// 执行

    } catch (SQLException e) {
      e.printStackTrace();
    } finally {
      try {
        // 关闭IO流
        proc.close();
        DBUtil.closeAll(null, pst, conn);
      } catch (Exception e) {
        e.printStackTrace();
      }
    }
  }

  /**
   * 执行存储过程 查询数据
   */
  public static void select_call() {
    Connection conn = DBUtil.getConnection();

    CallableStatement stmt;
    try {
      stmt = conn.prepareCall("{ call select_procedure(?, ?) }"); // 用此调用方法不能实现多行语法
      stmt.setString(1, "1");
      stmt.registerOutParameter(2, OracleTypes.CURSOR);
      stmt.execute();
      ResultSet rs = (ResultSet) stmt.getObject(2);
      while (rs.next()) {
        System.out.println(rs.getString("name"));
      }
    } catch (SQLException e) {
      e.printStackTrace();
    } finally {
      DBUtil.closeConnection(conn);
    }
  }
}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# Java调用Oracle存储过程  # Java调用Oracle存储过程详解实现代码  # Java Spring动态生成Mysql存储过程详解  # 详解java调用存储过程并封装成map  # MyBatis创建存储过程的实例代码_动力节点Java学院整理  # Java实现调用MySQL存储过程详解  # 详解Java的JDBC API的存储过程与SQL转义语法的使用  # java编程调用存储过程中得到新增记录id号的实现方法  # Java调用MySQL存储过程并获得返回值的方法  # java调用mysql存储过程实例分析  # Java中调用SQL Server存储过程详解  # java调用oracle分页存储过程示例  # java调用Oracle存储过程的方法实例  # Java下使用Oracle存储过程(详解)  # Java存储过程调用CallableStatement的方法  # 存储过程  # 第一个  # 希望能  # 谢谢大家  # 包中  # Connection  # sql  # DriverManager  # ResultSet  # SQLException  # OPEN  # STANDARD  # SYS  # import  # JDBC  # SELECT  # Statement  # driver 


相关文章: c# 在高并发场景下,委托和接口调用的性能对比  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  公众号网站制作网页,微信公众号怎么制作?  如何在建站宝盒中设置产品搜索功能?  建站之星IIS配置教程:代码生成技巧与站点搭建指南  深圳网站制作案例,网页的相关名词有哪些?  如何彻底卸载建站之星软件?  建站之星如何助力企业快速打造五合一网站?  如何在七牛云存储上搭建网站并设置自定义域名?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  简单实现Android文件上传  C#如何在一个XML文件中查找并替换文本内容  网站插件制作软件免费下载,网页视频怎么下到本地插件?  如何用花生壳三步快速搭建专属网站?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  沈阳制作网站公司排名,沈阳装饰协会官方网站?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  建站之星代理商如何保障技术支持与售后服务?  如何通过万网虚拟主机快速搭建网站?  高防服务器租用如何选择配置与防御等级?  如何通过免费商城建站系统源码自定义网站主题与功能?  小建面朝正北,A点实际方位是否存在偏差?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  视频网站app制作软件,有什么好的视频聊天网站或者软件?  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  建站之星2.7模板快速切换与批量管理功能操作指南  学校建站服务器如何选型才能满足性能需求?  建站之星安装步骤有哪些常见问题?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  建站VPS配置与SEO优化指南:关键词排名提升策略  山东网站制作公司有哪些,山东大源集团官网?  ppt制作免费网站有哪些,ppt模板免费下载网站?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  中山网站推广排名,中山信息港登录入口?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  建站主机服务器选购指南:轻量应用与VPS配置解析  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何用y主机助手快速搭建网站?  如何通过WDCP绑定主域名及创建子域名站点?  如何自定义建站之星网站的导航菜单样式?  如何快速配置高效服务器建站软件?  ,网站推广常用方法?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何快速查询网站的真实建站时间?  如何将凡科建站内容保存为本地文件?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  高端云建站费用究竟需要多少预算? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。