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
相关文章:
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
教程网站设计制作软件,怎么创建自己的一个网站?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
制作网站的软件免费下载,免费制作app哪个平台好?
Python路径拼接规范_跨平台处理说明【指导】
黑客如何利用漏洞与弱口令入侵网站服务器?
简历在线制作网站免费,免费下载个人简历的网站是哪些?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何实现建站之星域名转发设置?
山东云建站价格为何差异显著?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
微信小程序 input输入框控件详解及实例(多种示例)
制作网站的公司有哪些,做一个公司网站要多少钱?
如何自定义建站之星模板颜色并下载新样式?
详解jQuery中基本的动画方法
如何快速搭建个人网站并优化SEO?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
如何在建站宝盒中设置产品搜索功能?
无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
如何快速查询网站的真实建站时间?
Python文件管理规范_工程实践说明【指导】
网站图片在线制作软件,怎么在图片上做链接?
建站主机SSH密钥生成步骤及常见问题解答?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
如何使用Golang table-driven基准测试_多组数据测量函数效率
模具网站制作流程,如何找模具客户?
jQuery 常见小例汇总
建站中国官网:模板定制+SEO优化+建站流程一站式指南
山东网站制作公司有哪些,山东大源集团官网?
建站之星安装路径如何正确选择及配置?
如何通过宝塔面板实现本地网站访问?
长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?
建站之星如何快速更换网站模板?
江苏网站制作公司有哪些,江苏书法考级官方网站?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
视频网站制作教程,怎么样制作优酷网的小视频?
大连 网站制作,大连天途有线官网?
建站主机功能解析:服务器选择与快速搭建指南
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
如何高效生成建站之星成品网站源码?
全景视频制作网站有哪些,全景图怎么做成网页?
如何自定义建站之星网站的导航菜单样式?
如何零基础开发自助建站系统?完整教程解析
西安大型网站制作公司,西安招聘网站最好的是哪个?
*请认真填写需求信息,我们会在24小时内与您取得联系。