开发者

How can I access two Oracle databases with different versions (8i and 9) using perl?

开发者 https://www.devze.com 2023-01-30 22:27 出处:网络
I\'m currently accessing an Oracle database version 9i (9.2.0.8.0) using perl modules DBI (1.613) and DBD::Oracle (1.26). The current scope of the project now require开发者_StackOverflow社区s that I a

I'm currently accessing an Oracle database version 9i (9.2.0.8.0) using perl modules DBI (1.613) and DBD::Oracle (1.26). The current scope of the project now require开发者_StackOverflow社区s that I access a version 8i (8.1.7.4.0 ) Oracle database and, according to the DBD::Oracle project, I can only access this second database with a DBD::Oracle version 1.20 or below.

I know I could possibly use the DBD version 1.20 to access both databases, but I was wondering if its possible to have installed the two versions of the DBD module and use the acceptable version for each database (less prone to errors).


I don't believe that the server version has any bearing on the DBD::Oracle version you can use, only the version of the client libraries that you install. The 9.2, 10.1, and 10.2 versions of the Oracle client libraries support connecting to Oracle server 8.1.7.4, and the latest version of DBD::Oracle remains compatible with all client libraries from 9.2 up, so I don't think that you will actually have any problem at all. However, if you install the version 11 client, you will lose the ability to connect to server versions below 9.2.0.


Install the different versions of DBI/DBD::Oracle into two different places, see INSTALL_BASE/--install_base. Access them seperately by setting PERL5LIB appropriately.

local::lib helps you automate this whole affair.


If you want to access the two database versions from the same program run you can do as follows:

  • install both versions in your system using local::lib

  • run a DBD::Proxy server with @LIB configured to load one version of DBD::Oracle

  • run your script with @LIB configured to load the other version of DBD::Oracle

  • in your script connect to one database using DBD::Oracle as usual and to the other one through the proxy.

0

精彩评论

暂无评论...
验证码 换一张
取 消