Oracle探究_JAVA存储过程_开发指引《中》
mhr18 2024-12-17 13:46 13 浏览 0 评论
HLS HLS/MD120
1.5 返回PLSQL集合变量
有一种业务场景是在主逻辑处理完后需要返回多个数据。
结合JAVA不能类似PLSQL存储过程有OUT参数,只能开发返回函数形式的Method,以下
将介绍JAVA存储过程返回PLSQL集合变量的方式.
1.开发思路
(1)Oracle DB中声明Table集合变量;
(2)JAVA中使用ArrayDescriptor对象描述TABLE集合变量;
(3)创建JAVA数组存储变量;
(4)使用oracle.sql.ARRAY匹配映射PLSQL中的Table集合变量
2.示例
Company Confidential – For BDLL & HAND use only 7
HLS HLS/MD120
} catch (Exception e) {
// System.err.println(e.getMessage());
e.printStackTrace();
l_err_msg = "GetJdbcConnection-" + e.getMessage();
l_rtn_status = "E";
// throw new Exception("GetJdbcConnection-"+l_err_msg);
}
//..............
//省掉中间内容
//处理返回值
ArrayDescriptor l_rtn_array_descriptor =
ArrayDescriptor.createDescriptor("CUX_PER_RTN_JPC_MSG_T", ws_conn); if (l_rtn_status.equals("S")) {
l_rtn_data[0] = l_rtn_status;
l_rtn_data[1] = "";
l_rtn_data[2] =g_esb_batch_no;
l_rtn_array =
new ARRAY(l_rtn_array_descriptor, ws_conn, l_rtn_data);
} else {
l_rtn_data[0] = l_rtn_status;
l_rtn_data[1] = l_err_msg;
l_rtn_data[2] =g_esb_batch_no;
l_rtn_array =
new ARRAY(l_rtn_array_descriptor, ws_conn, l_rtn_data);
}
ws_conn.commit();
ws_conn.close();
return l_rtn_array;
}
Company Confidential – For BDLL & HAND use only 8
HLS HLS/MD120
l_rtn_line_t cux_per_rtn_jpc_msg_t;
l_msg_data VARCHAR2(1000);
BEGIN
x_return_status := hss_api.start_activity(p_pkg_name => g_pkg_name, p_api_name => l_api_name,
p_savepoint_name => l_savepoint_name, p_init_msg_list => p_init_msg_list);
OPEN csr_line; FETCH csr_line
INTO l_esb_base_data,
l_esb_biz_data;
CLOSE csr_line;
l_rtn_line_t := cux_per_rtn_jpc_msg_t();
----调用解析程序解析数据,并插入数据中间表中
l_rtn_line_t.delete;
l_rtn_line_t := PraseMainProcess(p_base_parameter => l_esb_base_data, p_biz_parameter => l_esb_biz_data,
p_batch_id => g_batch_id);
log('l_rtn_line_t(1)=' || l_rtn_line_t(1));
log('l_rtn_line_t(2)=' || l_rtn_line_t(2));
log('l_rtn_line_t(3)=' || l_rtn_line_t(3));
IF g_rtn_message_tbl(1).process_status <> 'S' THEN
--l_err_message := l_err_message || x_msg_data;
x_return_status := fnd_api.g_ret_sts_error;
raise_exception(x_return_status);
END IF;
x_return_status := hss_api.end_activity(p_pkg_name => g_pkg_name, p_api_name => l_api_name,
p_commit => p_commit,
x_msg_count => x_msg_count,
x_msg_data => x_msg_data);
EXCEPTION
WHEN fnd_api.g_exc_error THEN
WHEN fnd_api.g_exc_unexpected_error THEN
WHEN OTHERS THEN
END process_json;
1.6 发布程序工具-LoadJava
对于开发的程序最终是通过LOADJAVA程序发布进数据,后面内容中也会介绍更加
快捷的Jdeveloper发布进数据库,但归根结底仍是使用了LOADJAVA程序。
1.LoadJava说明
Loadjava是加载Java源文件、Java类文件和Java资源文件的实用程序,它可以用来
验证字节码,并将Java类和JAR文件布置到数据库中。它既可以通过命令行调用,也
可以通过包含于DBMS_JAVA类中的loadjava()方法调用。如下为一JAR程序装载进数
据库:
Company Confidential – For BDLL & HAND use only 9
HLS HLS/MD120
username/password[@database]为要导入的目标ORACLE DB,其中格式-option选项如下:
2.DropJava说明 Dropjava主要用于从ORACLE DB中删除由loadjava程序上载的JAVA程序。 10
Company Confidential – For BDLL & HAND use only
HLS HLS/MD120
在删除JAVA程序时,文件名必须与loadjava时使用的”文件路径+文件名”必须一致,不然命令不能够找到对应JAVA程序进行删除。如:”/d01/oracle/testappl/cux/11.5.0/admin/sqljdbc.jar”两着必须一致。
3.可能出现的问题 在loadjava过程中,可能存在这样那样的问题导致不成功。 1) 查错:除命令行抛出的错,数据库中也可以查询对应JAVA的错误;
2) DB服务器环境变量问题; 主要可能是由于ORACLE_HOME,JAVA_HOME,CLASSPATH这些环境变量没有设置,以linux为例可通过export命令修改SESSION层得环境变量。如 3) 出现异常: ClassNotFound或者ORA-29534: referenced object <class name> could not be resolved error错误; 原因说明: 所有装载进数据库的CLASS都引用到了装载到数据库某一SCHEMA的CLASS。已存在于DB中预定义的JAVA应用程序,如java.lang.*(JDK),都被装载到了PUBLIC SCHEMA中,所以所有程序都能访问使用预定义的程序。若要装载的CLASS引用了其他外部CLASS,必须将外部CLASS装载到同一个SCHEMA中。 比如,当前SCHEMA为SCOTT,装载有依赖其他CLASS的CLASS时,loadjava在解析时会先在SCOTT SCHEMA搜索是否存在依赖的CLASS,若不存在会进一步在PUBLIC SCHEMA下搜索,若搜锁不到,则会抛出以上异常. 解决办法2个: 11
Company Confidential – For BDLL & HAND use only
HLS HLS/MD120
a) 找到对应引用类,装载入同一个SCHEMA;
b) 若知道引用的类在哪个SCHEMA存在,比如在APPS,则使用命令:
4) Loadjava: No such file or directory 由于克隆环境导致LOADJAVA环境变量读取错误: /u01/PROD/db/tech_st/11.2.0/jdk/jre//bin/java: No such file or directory; 但其实正确的目录应为/u01/TEST下的ORACLE_HOME. 此问题的解决办法是检查并修改$ORACLE_HOME\bin\loadjava的程序文件,将其/u01/PROD/db/tech_st/11.2.0改为$ORACLE_HOME 12
Company Confidential – For BDLL & HAND use only
HLS HLS/MD120
2.开发实例
2.1 实例说明
1.实例逻辑 实例简单逻辑是将ORACLE DB一张TABLE的数据传递到SQL SEVER数据库中;
2.环境 1) DB:ORACLE 11G,9i以上数据库即可支持; 2) IDE开发工具:Jdeveloper 10G,若要用IDE直接发布程序,Jdeveoper版本必须为10G版本以上; 3) SQL SERVER 2005; 3.实例相关数据库对象 此步创建本实例所需的相关数据库对象
13
Company Confidential – For BDLL & HAND use only
LAST_UPDATE_LOGIN NUMBER, ATTRIBUTE_CATEGORY VARCHAR2(30), ATTRIBUTE1 VARCHAR2(240), ATTRIBUTE2 VARCHAR2(240), ATTRIBUTE3 VARCHAR2(240), ATTRIBUTE4 VARCHAR2(240), ATTRIBUTE5 VARCHAR2(240), ATTRIBUTE6 VARCHAR2(240), ATTRIBUTE7 VARCHAR2(240), ATTRIBUTE8 VARCHAR2(240), ATTRIBUTE9 VARCHAR2(240), ATTRIBUTE10 VARCHAR2(240), ATTRIBUTE11 VARCHAR2(240), ATTRIBUTE12 VARCHAR2(240), ATTRIBUTE13 VARCHAR2(240), ATTRIBUTE14 VARCHAR2(240), ATTRIBUTE15 VARCHAR2(240) ); comment on table CUX.CUX_PUB_DB_INFO is 'DB信息维护'; comment on column CUX.CUX_PUB_DB_INFO.DB_SEQ_ID is '序列'
; comment on column CUX.CUX_PUB_DB_INFO.DB_KEY is 'DB连接简称'; comment on column CUX.CUX_PUB_DB_INFO.DB_TYPE is 'DB类型:SQLSERVER;DB2;ORACLE;SYBASE;MYSQL'; comment on column CUX.CUX_PUB_DB_INFO.JDBC_DRIVER is 'JDBC 驱动'; comment on column CUX.CUX_PUB_DB_INFO.DB_URL is 'JDBC 连接'; comment on column CUX.CUX_PUB_DB_INFO.USER_NAME is '用户'; comment on column CUX.CUX_PUB_DB_INFO.PWD is '密码'; comment on column CUX.CUX_PUB_DB_INFO.DB_DESC is 'DB连接描述'; comment on column CUX.CUX_PUB_DB_INFO.OBJECT_VERSION_NUMBER is '行版本号,用来处理锁'; alter table CUX.CUX_PUB_DB_INFO add constraint CUX_PUB_DB_INFO_PK primary key (DB_KEY); Create Unique Index CUX.CUX_PUB_DB_INFO_U1 On CUX.CUX_PUB_DB_INFO(DB_SEQ_ID) tablespace APPS_TS_TX_IDX; Create Sequence CUX.CUX_PUB_DB_INFO_S Start With 10001; Create Synonym APPS.CUX_PUB_DB_INFO_S For CUX.CUX_PUB_DB_INFO_S; Create Synonym APPS.CUX_PUB_DB_INFO For CUX.CUX_PUB_DB_INFO; 14 Company Confidential – For BDLL & HAND use only
2.2 创建JAVA程序
1.创建JAVA PROJECT
进入JDEV 10G->NEW PROJECT:CUXEMPJPC
2.设置JDEV工具的JDK与管理JAR
JAVA PROCEDURE基本工作环境为ORACLE数据库本身的JVM,因而
开发的要装载进DB的JAVA程序编译所用的JDK最好与ORACLE DB所
使用JDK版本一致或者相兼容;
(1)本实例使用11G数据库,如下为数据库JDK版本1.5
Company Confidential – For BDLL & HAND use only 15
(2)添加
JDK PATH
(3)更改
JDK
Company Confidential – For BDLL & HAND use only 16
3.创建JAVA程序
(1).使用NEW..
.
(2).编写JAVA程序
Company Confidential – For BDLL & HAND use only 17
// conn=DriverManager.getConnection(url,userName,password);
conn = DriverManager.getConnection(remote_url);
System.out.println("REMOTE Connection Successful!");
} catch (Exception e) {
errmsg = e.getMessage();
e.printStackTrace();
}
return conn;
}
public Connection getlocalConnection() throws Exception {
Connection local_conn = null;
try {
// Class.forName("oracle.jdbc.driver.OracleDriver");
// local_conn
=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:ORCL","scott","orcl");
local_conn =
DriverManager.getConnection("jdbc:default:connection:");
System.out.println("Local DB Connection Successful!");
} catch (Exception e) {
errmsg = errmsg + e.getMessage();
e.printStackTrace();
}
return local_conn;
}
public String geterr() {
return this.errmsg;
}
public static void emp_transfer(String rt_url,
String rt_driver) throws SQLException {
cuxemptransfer cef = new cuxemptransfer();
cef.remote_driver = rt_driver;
cef.remote_url = rt_url;
Connection remote_conn = null;
Connection localconn = null;
String rt_sql =
"INSERT INTO cux_hr_people_import_temp(employee_number, last_name, pos_date, sex, sfz_num) " +
"VALUES(?, ?, ?, ?, ?)";
String local_sql =
"select employee_number, last_name, pos_date, sex, sfz_num from
cux_hr_people_import_temp";
try {
remote_conn = cef.getConnection();
localconn = cef.getlocalConnection();
Statement local_stmt = localconn.createStatement();
ResultSet res = local_stmt.executeQuery(local_sql);
//传递数据到异构数据库
PreparedStatement rt_pstmt = remote_conn.prepareStatement(rt_sql); while (res.next()) {
rt_pstmt.setString(1, res.getString("EMPLOYEE_NUMBER"));
rt_pstmt.setString(2, res.getString("LAST_NAME"));
rt_pstmt.setDate(3, res.getDate("POS_DATE"));
rt_pstmt.setString(4, res.getString("SEX"));
rt_pstmt.setString(5, res.getString("SFZ_NUM"));
//批语句
rt_pstmt.addBatch();
}
// rt_pstmt.execute();
int[] updateCounts = rt_pstmt.executeBatch();
Company Confidential – For BDLL & HAND use only 18
对于学习有困难不知道如何提升自己可以加扣:578024144进行交流得到帮助,获取学习资料
相关推荐
- AlmaLinux 9.6发布:升级工具、初步支持IBM Power虚拟化技术
-
IT之家5月21日消息,科技媒体linuxiac昨日(5月20日)发布博文,报道称代号为SageMargay的AlmaLinux9.6发行版已上线,距上一版本9.5发...
- Java最新学习路线,系统全面,零基础适用
-
首先,我个人比较推崇的学习方法是:先学java前段,也就是HTML,css,js,因为学习java以后肯定是往javaee方向发展的,学习完前端,在学习后端很多东西比计较容易理解!其中J2SE是关键...
- 深入理解数据库事务(数据库事务处理的理解)
-
Transaction作为关系型数据库的核心组成,在数据安全方面有着非常重要的作用,本文会一步步解析事务的核心特性,以获得对事务更深的理解。什么是事务数据库几乎是所有系统的核心模块,它将数据有条理地保...
- IvorySQL 4.4 发布(1044mysql)
-
IvorySQL4.4已于2025年3月10日正式发布。新版本全面支持PostgreSQL17.4,新增多项新功能,并修复了已知问题。增强功能PostgreSQL17.3增强功...
- Oracle 与 Google Cloud 携手大幅扩展多云服务
-
据DCD4月10日报道,甲骨文(Oracle)与谷歌云(GoogleCloud)深化合作,全力扩展多云产品。双方计划为OracleDatabaseGoogleCloud解决方案新增11...
- Izzi 利用 Oracle 云提高计费效率和客户体验
-
据thefastmode网5月2日报道,墨西哥电信运营商Izzi宣布采用Oracle云基础设施(OCI),对其业务支持系统(BSS)进行现代化改造增强客户体验,已经成功完成。通过在OCI上运行...
- 好莱坞群星也有明星脸?硅谷科技名人本尊分身比一比
-
假如有部电影齐聚了众科技名人角色,如同许多好莱坞大牌卡司所共同主演的《瞒天过海》(Ocean’sEleven)那样,演出彼此在商场上竞逐、或共同对抗外来竞争捍卫硅谷的故事,更在剧中有不少对手戏,会不...
- 澳大利亚Find My iPhone被黑 多人被黑客锁机
-
FindMyiPhone本来是一个用于协助找回被盗手机的好工具,但是现在,澳洲的苹果用户发现他们的FindMyiPhone变成了黑客的帮凶。昨天,这名自称为OlegPliss的黑客使用Fin...
- 服务器密码错误被锁定怎么解决(服务器密码失效)
-
#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...
- 凌晨突发的数据库重大故障,我排查了一整天……
-
春节期间过得太热闹了,上班确实没啥状态,这不刚发生的一个重大性能故障,排查了整整一天,后面的领导都站成了一排,本次把故障发生的详细分析过程分享给大家!本次故障发生在凌晨,核心应用卡顿非常严重,Orac...
- Oracle锁表紧急处理!3招快速解锁方案
-
开篇:突发故障现场凌晨1点,某电商系统突然卡顿,数千笔支付订单无法完成——数据库出现死锁,技术团队紧急响应...(遇到类似情况的,欢迎在评论区分享经历)一、问题重现:死锁是如何产生的?典型场景:问题根...
- JetBrains DataGrip Mac中文破解版V2025.1下载安装教程
-
DataGripforMac是由JetBrains开发的数据库集成开发环境(IDE),专为数据库管理员和开发人员设计。它支持多种数据库(如MySQL、PostgreSQL、Oracle、SQ...
- 电脑装安卓系统,安卓X86版5.1 RC1下载
-
日前,谷歌放出了Android-x865.1的第一个候选版本Android-x865.1RC1,该版本基于Android5.1.1r24Lollipop开发,更新包括大量x86(32位)代...
- 来来来!一文告诉你Eclipse的正确安装使用姿势,你都清楚吗?
-
前言本学习笔记是有关如何设置Eclipse的详细说明。即使你天天在使用它,但是,相信我,或许你并不足够了解它。安装Java运行时环境Eclipse是Java应用程序,因此设置Eclipse的第一步是安...
- 分享收藏的 oracle 11.2.0.4各平台的下载地址
-
概述oracle11.2.0.4是目前生产环境用的比较多的版本,同时也是很稳定的一个版本。目前官网上已经找不到下载链接了,有粉丝在头条里要求分享一下下载地址。一、各平台下载地址1.1Linuxx...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)