[原创]用Oracle Java存储过程访问异构数据库

原创 2004年11月02日 10:58:00
   

在通常的企业应用中,数据库的类型可能会有多种,这些异构数据库之间的互连往往成为某个应用的瓶颈。解决的办法有多种,一是透过应用程序作为桥梁,在异构数据库之间牵线搭桥;二是数据库厂商提供的解决方案,比如SQL ServerLink Server, OracleTransparent Gateway技术;三是 通过数据库的应用扩展接口,例如OraclePL/SQL允许透过Java扩展访问外部数据库。

本文着眼于第三点,以Oracle连接SQL Server为例,探讨如何利用Java编写PL/SQL访问SQL Server,这点对于那些需要在非WINDOWS平台下访问SQL ServerOracle应用特别有意义。

本文中系统配置如下。

一、硬件及操作系统

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类。

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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 等。

 

4、  测试


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.inet.tds.TdsDriver").newInstance();

              String url="jdbc:inetdae7:10.24.09.192:1433?database=pubs";

              //       pubs为你的数据库的

              String user="sa";

              String password="123";

              conn= DriverManager.getConnection(url,user,password);

              String sql="select top 1 dtype,dname from test";

              stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

              rs=stmt.executeQuery(sql);

              if( rs.next()){

                     strResult = "The result from sql server is:dtype->" + rs.getString("dtype") + " dname->" + rs.getString("dname");

                    

              }

       

       } catch (InstantiationException e) {

              // TODO Auto-generated catch block

              e.printStackTrace();

        strResult = "operator fail in InstantiationException";

       } catch (IllegalAccessException e) {

              // TODO Auto-generated catch block

              e.printStackTrace();

        strResult = "operator fail in IllegalAccessException";

       } catch (ClassNotFoundException e) {

              // TODO Auto-generated catch block

              e.printStackTrace();

        strResult = "operator fail in ClassNotFoundException";

       } catch (SQLException e) {

              // TODO Auto-generated catch block

              e.printStackTrace();

        strResult = "operator fail in SQLException";

       }

    finally{

              try {

                     rs.close();

                     conn.close();

              } catch (SQLException e1) {

                    

                     e1.printStackTrace();

              }

       }

   

       return strResult;

}

 

值得注意的一点是,通过java存储访问SQL Server,如果返回一个结果集,在9i以下的Oracle版本是没有对应的数据类型可以转换的,一个可以变通的办法是要么返回一个字符串,要么将返回的结果集存放到Oracle中的表里。这样做是为了方便那些非Windows平台下无法直接访问SQL Server的程序。

六、外部程序调用java存储过程

调用java存储过程的方法跟调用一般的存储过程的方法是一样的.

Oracle Gateway11g R2访问异构数据库(MSSQL)配置文档--图文详细介绍

目录 1 前提条件 1 2 下载透明网关 1 3 解压安装透明网关 2 4 配置tnsnames 10 5 配置监听器 11 6 配置Gateway 13 7 重启Oracle服务 14 8 配置测试...
  • u013474104
  • u013474104
  • 2015年01月14日 09:49
  • 1924

让oracle访问到sqlserver中的数据(异构服务总结)

                                             采用透明网关技术,让oracle能轻松访问到sqlserver数据库中的数据。透明网关oracle在企业版本里...
  • tangnf
  • tangnf
  • 2007年05月25日 21:14
  • 3669

oracle异构rman迁移

目前rman支持的异构恢复、还原和复制版本及对应的平台如下: For Oracle Database 10g Release 2 and above releases: Solaris x86-...
  • lixz_2008
  • lixz_2008
  • 2012年08月11日 16:34
  • 1556

Oracle GoldenGate配置异构数据库数据传输(oracle到sqlserer)的dml操作(带pump进程)

实验环境: os01:Red Hat Enterprise Linux Server release 5.1 (32位) db01:oracle 10.2.0.1.0 os02:Window...
  • qq_36276335
  • qq_36276335
  • 2017年03月15日 17:41
  • 509

Oracle数据库异构服务原理及实例说明

由于历史的原因,在多数企业都同时存在多个数据库平台,在每个数据库平台上都运行着相关的一套或多套应用。随着单位业务不断扩大,如何在不影响现有应用运行的前提下,快速有效地整合这些分布在单位内部不同数据库平...
  • tomatofly
  • tomatofly
  • 2010年10月22日 14:35
  • 1209

多源异构环境下数据库的同步复制技术研究

参考链接:http://www.toutiao.com/i6253620263447953922/ 多源异构环境下数据同步复制技术的研究 电子技术应用 2016-02-21 13:44 摘 ...
  • iie_libi
  • iie_libi
  • 2017年04月01日 10:55
  • 387

异构数据库迁移 db2---oracle

异构数据库迁移 其他数据库迁移到oracle,以移植db2数据库对象到Oracle的操作说明为例,其他数据库迁移到oracle类似。 移植之平台和相关工具 OS:linux DBMS:db2...
  • aeolus_pu
  • aeolus_pu
  • 2013年06月28日 14:35
  • 1637

如何进行异构数据库同步

1、简介 最近一阵子笔者在进行完成同样功能的两套异构数据库系统的同步工作,有一些心得体会分享给大家,欢迎技术同仁拍砖。 该项目有一个运行若干年(5~10年)的旧系统,采用的是SQL Ser...
  • herobox
  • herobox
  • 2012年12月05日 12:56
  • 2540

Oracle存储过程访问同义词

创建一个同义词后,用sql可以访问,也可以修改数据,但是在存储过程中用到这个同义词时,报"表或视图不存在"的错误,上网查了下,原来要"在存储过程中访问公共同义词,必须直接对用户授权,而不能通过角色授权...
  • linminqin
  • linminqin
  • 2011年08月09日 11:07
  • 6003

ORACLE中怎样建DBLINK到异构数据库?

A :                        请参考.                          --建立ORACLE到SQL  SERVER的分布式--  1、安装  Microso...
  • pb8
  • pb8
  • 2007年12月12日 11:25
  • 2364
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[原创]用Oracle Java存储过程访问异构数据库
举报原因:
原因补充:

(最多只允许输入30个字)