如何解决支持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的函数。
我设法遵循以下步骤
- 下载了DBD-Oracle-1.73_01.tar.gz,并尝试安装erros。因此,首先下载并安装以下依赖项
2。下放的依赖项ExtUtils-MakeMaker-7.4和ExtUtils-ParseXS-35.tar.gz
-
下载了oracle sdk软件包12.2.0。它具有perl.jdk,plsql,sqlplus等。 oracle / 12.2.0 / client_1 / perl
-
设置ORACLE_HOME = / oracle / 12.2.0 / client_1和LD_LIBARRY_PATH = oracle / 12.2.0 / client_1 / perl
-
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开发库。
如果您在尝试时遇到问题,请在此处发布您在新问题中遇到的错误的详细信息,我们将尽力为您提供帮助。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。