支持Oracle和sybase的Perl解释器

问题描述

有人可以让我知道如何使用同时支持syb和ora模块的perl解释器在同一个perl脚本中同时使用sybase函数和oracle函数吗?

我目前在同一台计算机上运行2个perl解释器。

Sybase软件包基于以下版本的perl构建。我可以在sybase模式的README文件中看到该版本

 bash-4.1$ /usr/bin/perl -v
 This is perl,v5.10.1 (*) built for x86_64-linux-thread.

我能够在脚本中使用此解释器,并在使用sybase支持的函数从db *获取数据时成功编译

第一口译员 test1.pl

#!/usr/bin/perl

第二个perl解释器带有oracle sdk软件包。 它仅支持与Db交互的预言功能

bash-4.1$ /home/oracle/12.2.0/client_1/perl/bin/perl -v
This is perl 5,version 22,subversion 0 (v5.22.0) built for x86_64-linux-thread-multi->this is supporting only oracle*

test2.pl

#!/home/oracle/12.2.0/client_1/perl/bin/perl

我尝试使用来自/home/oracle/12.2.0/client_1/perl/bin/perl路径和我指向/usr/bin/perl的{​​{1}}文件的perl bin运行脚本时,从此路径@INC包含oracle模块,它将引发错误

所以我发现在1个perl版本上构建的oracle不能包含在其他版本的perl中

test3.pl

/home/oracle/12.2.0/client_1/perl/DBD/Oracle.pm

我可以有1个同时支持Sybase和Oracle功能的perl解释器版本吗?

我不是在谈论用于连接到oracle和sybase的DBI模块。

我的意思是连接后使用数据库处理程序支持oracle和sybase的函数。


我设法遵循以下步骤

  1. 下载了DBD-Oracle-1.73_01.tar.gz,并尝试安装erros。因此,首先下载并安装以下依赖项

2。下放的依赖项ExtUtils-MakeMaker-7.4和ExtUtils-ParseXS-35.tar.gz

  1. 下载了oracle sdk软件包12.2.0。它具有perl.jdk,plsql,sqlplus等。 oracle / 12.2.0 / client_1 / perl

  2. 设置ORACLE_HOME = / oracle / 12.2.0 / client_1和LD_LIBARRY_PATH = oracle / 12.2.0 / client_1 / perl

  3. cd DBD-Oracle-1.73_01 / -使用perl v5.10(perl Makefile.PL)执行

make && make install->此步骤引发很多错误

我假设使用oracle驱动程序模块以及oracle sdk客户端,这里是否有任何版本不匹配?

错误一览

#!/home/oracle/12.2.0/client_1/perl/bin/perl

---sydth/(EXEC.....)

解决方法

与Sybase数据库对话的标准方法是使用Perl的DBI(数据库接口)模块和DBD::Sybase(Sybase的数据库驱动程序)。同样,对于Oracle数据库,您将DBI与DBD::Oracle一起使用。

完全有可能将这两个模块安装在同一Perl安装中。将DBD :: Oracle添加到/usr/bin/perl中的Perl版本中可能最有意义。您可以通过运行

$ sudo cpan DBD::Oracle

在您的命令行上。请注意,您将需要对系统进行sudo访问,并且还需要C编译器和Oracle开发库。

如果您在尝试时遇到问题,请在此处发布您在新问题中遇到的错误的详细信息,我们将尽力为您提供帮助。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...