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
相关文章:
建站之星在线客服如何快速接入解答?
如何获取开源自助建站系统免费下载链接?
清除minerd进程的简单方法
高端云建站费用究竟需要多少预算?
动图在线制作网站有哪些,滑动动图图集怎么做?
网站制作免费,什么网站能看正片电影?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
建站之星如何修改网站生成路径?
做企业网站制作流程,企业网站制作基本流程有哪些?
移民网站制作流程,怎么看加拿大移民官网?
javascript中的try catch异常捕获机制用法分析
在线教育网站制作平台,山西立德教育官网?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
魔方云NAT建站如何实现端口转发?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
一键网站制作软件,义乌购一件代发流程?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
想学网站制作怎么学,建立一个网站要花费多少?
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何确认建站备案号应放置的具体位置?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
如何在服务器上三步完成建站并提升流量?
济南网站建设制作公司,室内设计网站一般都有哪些功能?
如何通过cPanel快速搭建网站?
网站制作网站,深圳做网站哪家比较好?
制作公司内部网站有哪些,内网如何建网站?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
如何快速生成高效建站系统源代码?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
常州企业网站制作公司,全国继续教育网怎么登录?
深圳网站制作案例,网页的相关名词有哪些?
如何通过WDCP绑定主域名及创建子域名站点?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
小建面朝正北,A点实际方位是否存在偏差?
完全自定义免费建站平台:主题模板在线生成一站式服务
建站之星安装需要哪些步骤及注意事项?
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
如何确保FTP站点访问权限与数据传输安全?
如何在阿里云服务器自主搭建网站?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
建站上传速度慢?如何优化加速网站加载效率?
北京的网站制作公司有哪些,哪个视频网站最好?
全景视频制作网站有哪些,全景图怎么做成网页?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
Swift开发中switch语句值绑定模式
*服务器网站为何频现安全漏洞?
nginx修改上传文件大小限制的方法
*请认真填写需求信息,我们会在24小时内与您取得联系。