perl - 在@INC 中找不到 DBD/Oracle.pm

标签 perl module

我正在尝试通过 DBI 连接到 Oracle,但无法正常工作。

我的设置:

# cat /proc/version 
Linux version 2.6.18-194.el5 (mockbuild@ca-build10.us.oracle.com) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-48)) #1 SMP Mon Mar 29 20:06:41 EDT 2010
# uname -i 
i386
# perl -v 
This is perl, v5.8.8 built for i386-linux-thread-multi 
<...>
# echo $ORACLE_HOME
/usr/lib/oracle/12.1/client

我正在尝试使用此脚本进行连接:

#!/usr/bin/perl
# dbi.pl
use warnings;
use strict;
use DBI;

$ENV{ORACLE_HOME}="/usr/lib/oracle/12.1";
$ENV{LD_LIBRARY_PATH}="/usr/lib/oracle/12.1/client/lib";
$ENV{NLS_LANG}="american_america.CL8MSWIN1251";

my $user='user';
my $pw='pw';
my $host='servername';
my $port='1521';
my $SID = 'SID';
my $source = "dbi:Oracle:$host;sid=$SID;port=$port";

my $dbh=DBI->connect($source,$user,$pw,{PrintError=>0,AutoCommit=>0,RaiseError=>1}) or die "Oracle:$DBI::errstr\n";

当我尝试执行它时出现错误:

#  ./dbi.pl
install_driver(Oracle) failed: Can't locate DBD/Oracle.pm in @INC (@INC contains: /usr/lib/perl5/site_perl/5.8.8/i386-linux-thread-multi /usr/lib/perl5/site_perl/5.8.8 /usr/lib/perl5/site_perl /usr/lib/perl5/vendor_perl/5.8.8/i386-linux-thread-multi /usr/lib/perl5/vendor_perl/5.8.8 /usr/lib/perl5/vendor_perl /usr/lib/perl5/5.8.8/i386-linux-thread-multi /usr/lib/perl5/5.8.8 .) at (eval 3) line 3.
Perhaps the DBD::Oracle perl module hasn't been fully installed,
or perhaps the capitalisation of 'Oracle' isn't right.
Available drivers: DBM, ExampleP, File, Proxy, Sponge, mysql.
 at ./dbi.pl line 21

我尝试重新安装 DBD-Oracle:

root@hostname:/tmp/DBD-Oracle-1.66# perl Makefile.PL
Using DBI 1.52 (for perl 5.008008 on i386-linux-thread-multi) installed in /usr/lib/perl5/vendor_perl/5.8.8/i386-linux-thread-multi/auto/DBI/

Configuring DBD::Oracle for perl 5.008008 on linux (i386-linux-thread-multi)

Remember to actually *READ* the README file! Especially if you have any problems.

Installing on a linux, Ver#2.6
Using Oracle in /usr/lib/oracle/12.1/client
DEFINE _SQLPLUS_RELEASE = "1201000100" (CHAR)
Oracle version 12.1.0.1 (12.1)

        Unable to locate an oracle.mk or other suitable *.mk
        file in your Oracle installation.  (I looked in
        /usr/lib/oracle/12.1/client/rdbms/demo/demo_xe.mk /usr/lib/oracle/12.1/client/rdbms/demo/demo_rdbms32.mk /usr/lib/oracle/12.1/client/rdbms/demo/demo_rdbms.mk /usr/lib/oracle/12.1/client/rdbms/lib/ins_rdbms.mk /usr/share/oracle/12.1/client/demo.mk under /usr/lib/oracle/12.1/client)

        The oracle.mk (or demo_rdbms.mk) file is part of the Oracle
        RDBMS product.  You need to build DBD::Oracle on a
        system which has one of these Oracle components installed.
        (Other *.mk files such as the env_*.mk files will not work.)
        Alternatively you can use Oracle Instant Client.

        In the unlikely event that a suitable *.mk file is installed
        somewhere non-standard you can specify where it is using the -m option:
                perl Makefile.PL -m /path/to/your.mk

        See the appropriate README file for your OS for more information and some alternatives.

     at Makefile.PL line 1187.
root@hostname:/tmp/DBD-Oracle-1.66#  ls /usr/lib/oracle/12.1/client/
total 8.0K
drwxr-xr-x 2 root root 4.0K Sep 24 13:23 bin/
drwxr-xr-x 2 root root 4.0K Sep 24 13:23 lib/
root@hostname:/tmp/DBD-Oracle-1.66#  

所以,我没有这个“rdbms”目录,因为我安装了 instantclient。有什么办法可以不用安装数据库就可以运行吗?

最佳答案

最近完整的 oracle 数据库安装没有安装 DBD::Oracle 所需的所有位。抱歉,我不记得您需要安装的可选位的名称。但是,另一种方法(也是一种更简单的方法)是下载 Oracle 即时客户端“basic”、“sdk”和“sqlplus”,将它们解压缩到某处并将您的 LD_LIBRARY_PATH 指向那个。它还使您独立于当前的 Oracle 数据库安装,这意味着如果您的 dba 升级它(或其中的一部分),您不需要考虑重建 DBD::Oracle。

顺便说一句,在你的 perl 脚本中设置你的 LD_LIBRARY_PATH 是行不通的——为时已晚。

关于perl - 在@INC 中找不到 DBD/Oracle.pm,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19401822/

相关文章:

perl - Perl 中的多级 'do'?

regex - 给定不完全包含在单词中的标记,我如何标记一个单词?

java - 使用 perl/java 将数据库中现有的图像代码重命名为新图像代码

perl - 如何让 Perl 的 Spreadsheet::WriteExcel 使用 VLOOKUP 创建公式?

node.js - 如何为同级目录中所需的脚本提供模块依赖项

python - 使 python 模块可用作 cli 工具的最简单方法

Perl 的 HTML::Element - 仅将后代转储为 HTML

c - 错误: dereferencing pointer to incomplete type -> passing structure to module

Python 3.7 和 psycopg2。导入错误: DLL load failed

string - ocaml 中的错误链接模块