免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2595 | 回复: 5
打印 上一主题 下一主题

求助各位大侠啊,用perl 在客户端无法连接Oracle服务器端 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-06 19:55 |只看该作者 |倒序浏览
求助各位大侠啊,用perl 在客户端无法连接Oracle服务器端,报错如下:
wyc@ubuntu-server:~/script$ ./dbi2.pl
DBI connect('host=192.168.121.1:XE','scott',...) failed: ORA-12154: TNS:could not resolve the connect identifier specified (DBD ERROR: OCIServerAttach) at ./dbi2.pl line 9

Can't call method "prepare" on an undefined value at ./dbi2.pl line 10.

tnsnames.ora 文件配置如下:
wyc@ubuntu-server:/usr/lib/oracle$ cat tnsnames.ora
XE=
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.121.1)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME=XE)
    )
  )

连接程序如下:

wyc@ubuntu-server:~/script$ cat ./dbi2.pl   
#!/usr/bin/perl -w

use DBI;

my $dbSid = "XE";
my $dbHost = "192.168.121.1";
my $dbUser = "scott";
my $dbPassword = "tiger";
my $dbh = DBI->connect("dbi:Oracle:host=$dbHostdbSid", $dbUser, $dbPassword) or print $!,"\n";#($DBI::errstr);
my $sth = $dbh->prepare("select * from table";
$sth->execute;
my @recs = "";
while ( my @recs=$sth->fetchrow_array) {
print $recs[0].":".$recs[1].":".$recs[2]."\n";
}
$dbh->finish;

$dbh->disconnect;

exit if(1);

已在百度、google搜索多时,无果,郁闷啊

论坛徽章:
0
2 [报告]
发表于 2011-11-06 22:34 |只看该作者
自已顶一下

论坛徽章:
0
3 [报告]
发表于 2011-11-07 10:36 |只看该作者
  1. my $dbh = DBI->connect('DBI:Oracle:host=$dbHost,sid=$dbSid;port=1521', '$dbUser',' $dbPassword') or print $!,"\n";#($DBI::errstr);
复制代码
前几天才用过,这样应该可以把

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
4 [报告]
发表于 2011-11-07 11:00 |只看该作者
回复 1# inchonline


http://search.cpan.org/~pythian/DBD-Oracle-1.34/Oracle.pm
$dbh = DBI->connect("dbi:Oracle:host=$host;sid=$sid", $user, $passwd);

论坛徽章:
0
5 [报告]
发表于 2011-11-07 22:52 |只看该作者
回复 4# jason680


    用其中一种已经连上了,感谢啊~~

$dbh = DBI->connect('dbi:Oracle:',"$dbUser\@XE","$dbPassword");

论坛徽章:
0
6 [报告]
发表于 2012-02-17 17:40 |只看该作者
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP