网站首页 > java教程 正文
HLS HLS/MD120
文档控制
1.1. 更改记录
1.2. 审阅记录
1.3. 分发人员
385326017.doc
Company Confidential – For BDLL & HAND use only
1
HLS HLS/MD120
目录
385326017.doc
文档控制
................................................................................................................................... 1 1.1. 更改记录
.................................................................................................................. 1 1.2. 审阅记录
.................................................................................................................. 1 1.3. 分发人员
.................................................................................................................. 1 1.Java存储过程
......................................................................................................................... 3 1.1 总体说明
..................................................................................................................... 3 1.2 必要设置
..................................................................................................................... 3 1.3 开发步骤
..................................................................................................................... 4 1.4 JDBC与JAVA存储过程
.............................................................................................. 5 1.5 返回PLSQL集合变量
................................................................................................. 7 1.6 发布程序工具-LoadJava
............................................................................................. 9 2.开发实例
.............................................................................................................................. 13 2.1 实例说明
................................................................................................................... 13 2.2 创建JAVA程序
......................................................................................................... 15 2.3 发布程序
................................................................................................................... 19 已解决及未解决的问题
......................................................................................................... 25 未解决的问题
.................................................................................................................. 25 已解决的问题
.................................................................................................................. 25 2
Company Confidential – For BDLL & HAND use only
HLS HLS/MD120
1.Java存储过程
1.1 总体说明
1.2 必要设置
385326017.doc
简述 JAVA 存储过程是以JAVA语言编写的在数据库服务器JVM上运行的JAVA 程序,调用使用方式与PL/SQL 存储过程类同。 利用Java存储过程沟通SQL、XML、Java、J2EE和Web服务。本文将介绍Oracle如何在数据库内启用基于Java的存储过程。还会介绍Java存储过程如何访问数据,以及如何创建基本Java存储过程,实现异构数据库之间的数据互访。 ORACLE JVM 任何JAVA应用程序的运行,都脱离不了JVM。 自Oracle8i版本1(Oralce8.1.5)开始,Oracle便提供紧密集成的Java虚拟机(JVM),JVM支持Oralce的数据库会话期结构,这使得在数据库内运行JAVA程序具有实际意义. Oracle 9i和10g版本的数据库为开发服务器端或内部Java程序组件提供了一个健壮的体系结构。它包括: 1) 操作系统的平台依赖性,例如UNIX、 LINUX、 Microsoft Windows; 2) 依赖Oracle数据库的文件和库管理; 3) 独立于平台的JVM (Java Virtual Machine,Oracle Java虚拟机); 4) Java内核类库,兼容不同的平台; 5) Oracle支持的Java API (Application Programming Interfaces,应用程序接口),如SQLJ、JDBC和JNDI; 6) Oracle的PL/SQL存储对象,为SQL和PL/SQL程序之间提供接口,就像服务器端Java类库一样。 JAVA程序的运行需要JVM,而各种复杂程序的开发则需要各种丰富的JAVA API,数据库提供了基本的扩展API,如ORACEL JDBC; 若要实现特定功能则组要装载特定JAR或者JAVA开源程序进入ORACLE DB.如本文实例的需要访问MS SQL SERVER数据库,此种情况则需要装载Micro SOFT官网上SQL SERVER JDBC程序JAR包。 对于JAVA PROCEDURE的开发主要前提是ORACLE DB必须安装ORACLE JVM,一般情况下属于必须安装选项; 1.检查Oracle JVM 以下查询产品安装情况 3
Company Confidential – For BDLL & HAND use only
HLS HLS/MD120
2.Oracle JVM配置
1) JAVA内存设置:必须设置ORACLE DB的JAVA内存参数
3.装载必要的外部JAR
开发JAVA存储过程实质为开发JAVA程序,除JDK包外,在实际开发过程中需要使用
LOADJAVA程序附加特定的外部JAR;
1.3 开发步骤
此节使用源码引自章节: Oracle Database Java Developer’s Guide-Java Stored Procedures Application Example
1.创建JAVA应用程序
可以使用IDE开发工具进行JAVA程序编写,如
JDeveloper;
开发的最终调用的JAVA方法必须为static类型方法.如
385326017.doc
Company Confidential – For BDLL & HAND use only 4
HLS HLS/MD120
2.发布Java程序到Oracle
完成的JAVA程序,要使之能在数据库运行,可以打包成JAR或者单纯的CLASS程序,通
过LOADJAVA命令装载到ORACEL DB,或者以CREATE JAVA语句创建;如:
注:发布JAVA代码到数据库,Jdeveloper有提供相关的功能可已直接将代码发布到
ORACLE DB.
3.PL/SQL”封装(wrappers)”JAVA
ORACLE DB中需要调用装载的JAVA程序,需用PL/SQL封装成存储过程形势;
编译之后将于普通PL/SQL 存储过程使用方式相同。
1.4 JDBC与JAVA存储过程
JAVA 存储过程一大作用就在于异构数据库系统间的数据集成,JDBC与JAVA 存储过
程的结合使用将此需求以一种新的方式实现。
385326017.doc
Company Confidential – For BDLL & HAND use only 5
HLS HLS/MD120
Java 数据库连接(JDBC)由一组用 Java 编程语言编写的类和接口组成。以下将主
要简单介绍ORACLE、DB2、MS SQL SERVER、MY SQL,SYBASE这些主流数据的JDBC连接。
1.SQL SERVER JDBC连接
通过以下代码获取数据库JDBC连接以访问数据库;
注意:在JAVA 存储过程中访问SQL SERVER数据库,必须把从数据库产品厂
商下载的JDBC工具包LoadJava装载进数据库,SQL SERVER JDBC工具包为
sqljdbc.jar;
2.其他常用DB的JDBC连接
其他常用DB的JDBC连接获取与以上代码无甚区别,各个DB连接的区别就在所使用的
JDBC驱动与连接符不同,这是由于它们所使用的JDBC是各自DB厂商开发的JDBC工具
包程序;
以下将列出这些DB所使用的
JDBC程序列表:
使用的JDBC相关信息:
注意:对于ORACLE DB服务端的JDBC连接的获取,由于DB服务端JDBC DRIVER在默认的
SESSION和上下文中运行,所以对于ORACLE DB的JDBC连接直接可以通过如下代码获
取:
385326017.doc
Company Confidential – For BDLL & HAND use only 6
对于学习有困难不知道如何提升自己可以加扣:578024144 进行交流得到帮助,获取学习资料
- 上一篇: hive存储过程(hive 行存储 列存储)
- 下一篇: 「每天一道面试题」MySQL存储过程
猜你喜欢
- 2025-05-05 数据库连接池在Java应用中的应用(数据库连接池的好处)
- 2025-05-05 Java中常见的内存泄 漏场景及解决方案
- 2025-05-05 JVM 深度解析:运行时数据区域、分代回收与垃圾回收机制全攻略
- 2025-05-05 MongoDB与Java的高效结合:打造数据存储的双赢局面
- 2025-05-05 Java学习日志 - 一篇文章解释清楚Java的引用数...
- 2025-05-05 一文吃透Java内存模型:从原理到实战
- 2025-05-05 Java虚拟机内存管理深度解读(java虚拟机启动内存参数)
- 2025-05-05 SpringBoot对于非结构的JSON数据进行动态存储?
- 2025-05-05 13 张图解 Java 中的内存模型(java内存模型有哪些)
- 2025-05-05 「zookeeper详解图文七」ZK集群服务节点角色、状态以及数据存储
你 发表评论:
欢迎- 最近发表
-
- Mozilla Firefox 139 Beta已上线 提供更快的HTTP/3上传速度
- Win8专享拷贝能暂停,Win7其实也可以
- ASP.NET利用WEBUPLOADER实现超大文件分片上传、断点续传
- 河汉大大的《断点续传》-------黑暗哨兵和向导的绝美爱恋
- 用C# 实现断点续传 (HTTP)
- 开源断点续传下载软件FDM获推6.21.0.5639版更新
- 前端大文件切片上传,断点续传、秒传等解决方案,VUE中使用实例
- SpringBoot 实战:文件上传之秒传、断点续传、分片上传
- 一文搞定SpringBoot分片上传、断点续传、大文件极速秒传功能
- SPRING-BOOT实现HTTP大文件断点续传分片下载
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)