用Oracle Java存储过程访问异构数据库 ..docVIP

用Oracle Java存储过程访问异构数据库 ..doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用Oracle Java存储过程访问异构数据库 .

用Oracle Java存储过程访问异构数据库 . 在通常的企业应用中,数据库的类型可能会有多种,这些异构数据库之间的互连往往成为某个应用的瓶颈。解决的办法有多种,一是透过应用程序作为桥梁,在异构数据库之间牵线搭桥;二是数据库厂商提供的解决方案,比如SQL Server的Link Server, Oracle的Transparent Gateway技术;三是 通过数据库的应用扩展接口,例如Oracle的PL/SQL允许透过Java扩展访问外部数据库。 本文着眼于第三点,以Oracle连接SQL Server为例,探讨如何利用Java编写PL/SQL访问SQL Server,这点对于那些需要在非WINDOWS平台下访问SQL Server的Oracle应用特别有意义。 本文中系统配置如下。 一、硬件及操作系统 Dell Intel Xeon Server + Windows2000 Server 二、数据库环境 Oracle 8.1.7 三、安装 欲使Oracle支持Java,必须在Oracle上安装Jserver组件。在安装Oracle软件的时候,如果选择典型安装,Jserver是默认安装的,如果选择自定义安装,记得选择Jserver组件。还有另一种方法可以手工安装Jserver.办法是:进入Oracle安装目录下的/javavm/install目录,以sys用户的身份执行initjvm.sql,这个脚本会为数据库配置一个Java运行环境,同时会把基本的java类库装载到数据库中去。建议在执行此脚本之前,先阅读/javavm/readme.txt文件,里面包括安装前对数据库某些配置的必要修改的说明,以及对脚本执行出错的处理描述。 脚本执行时间大约10分钟,如果失败可以重新执行。 在脚本执行完毕后,用DBA Studio工具可以看到多了Jserver这个东西。 四、权限赋予 要能在Oracle中执行Java存储过程,需要一个javauserpriv的角色,这个角色在安装Jserver后会自动创建,将此角色赋给各个Oracle的使用账号。 五、编写Java存储过程 1、 在本地机器上编写一个Java类。 public class TEST { public static void main (String args[]) { System.out.println(HELLO THIS iS A JAVA PROCEDURE); } } 2、 用loadjava指令将写好的java类文件上传到数据库中。 例如:C:/loadjava –u test/oracle@mytest -o –v –r d:/TEST.java 当然,除了上载.java文件,也可以上载.class/.jar/.properties文件,上载后的文件在数据库中会以Object的形式存在. 文件若有改动,可以重新上载,会将以前的版本覆盖掉。 3、 生成声明接口 上载的java类需要发布成一个可供调用的接口,这些接口可以是Store Procesure/Trrigger/Function 等。 SQLcreate or replace procedure test_java as language java name TEST.main(java.lang.String[]); / 4、 测试 SQL set serveroutput on size 5000 SQL call dbms_java.set_output(5000); 调用完成。 SQL execute test_java; HELLO THIS iS A JAVA PROCEDURE PL/SQL 过程已成功完成。 SQL call test_java(); HELLO THIS iS A JAVA PROCEDURE 调用完成。 5、 以上是一个简单的java 类,其实如果要在Oracle中访问到非Oracle的数据库,只 要在java 类中实现访问非Oracle数据库就可以了。 public static String getStringFomSql(){ String strResult =; Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName(com.

文档评论(0)

sy78219 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档