通过Perl连接到Teradata

6

有人在这方面获得了成功吗?网上没有太多的参考资料,我已经用谷歌搜索了所有相关的结果。这是我的脚本:

#!/usr/bin/perl

use DBI;
use DBD::ODBC;

$user = "user";
$pw = "pw";
$ip = "192.168.1.0"

#DBI->trace(DBD::ODBC->parse_trace_flags('odbconnection'));

#my $connect_attrs = { PrintError => 0, RaiseError => 1, AutoCommit => 1 };

my $dbh = DBI->connect("dbi:ODBC:$ip", $user, $pw);

错误信息:
DBI connect('192.168.1.0','user',...) failed: (no error string) at ./teradata.pl line 13

这两行被注释掉的代码是我之前尝试连接数据库时留下的残余代码。

更新:以下是我使用DBD模块尝试连接数据库的先前努力。

#!/usr/bin/perl

use DBI;

$user = "xxxx";
$pw = "xxxx";

my $dbh = DBI->connect("dbi:Teradata:tdsn", $user, $pw);

错误:

DBI connect('tdsn','xxxx',...) failed: Unable to get host address. at ./teradata.pl line 12

第二次尝试:

#!/usr/bin/perl

use DBI;

$user = "xxxx";
$pw = "xxxx";

my $dbh = DBI->connect("dbi:Teradata:192.168.1.0", $user, $pw);

错误:

DBI connect('192.168.1.0','xxxx',...) failed: Deprecated logons are not allowed by administrator.  Upgrade client software to latest version. at ./teradata.pl line 12

Third...

#!/usr/bin/perl

use DBI;
use DBD::ODBC;

$user = "xxxx";
$pw = "xxxx";

my $dbh = DBI->connect("dbi:ODBC:tdsn", $user, $pw);

.odbc.ini

[ODBC]
InstallDir              = /usr/odbc
Trace           = 0
TraceDll                = /usr/odbc/lib/odbctrac.so
TraceFile               = /home/xxxx/odbctrace.log
TraceAutoStop           = 0

[ODBC Data Sources]
default         = tdata.so
testdsn         = tdata.so

[default]
Driver          = /usr/odbc/drivers/tdata.so
Description             = Default DSN is Teradata 5100
DBCName         = **ip_addr**
LastUser                = DLPStats
Username                = xxxx
Password                = xxxx
Database                = MSS_TEMP
DefaultDatabase         = MSS_TEMP

[tdsn]
Driver=/usr/odbc/drivers/tdata.so
Description=Teradata running Teradata V1R5.2
DBCName=**ip_addr**
LastUser=
Username=xxxx
Password=xxxx
Database=
DefaultDatabase=

错误:

DBI connect('tdsn','xxxx',...) failed: (no error string) at ./teradata.pl line 13

odbcinst.ini

[ODBC DRIVERS]
Teradata=Installed

[Teradata]
Driver=/usr/odbc/drivers/tdata.so
APILevel=CORE
ConnectFunctions=YYY
DriverODBCVer=3.51
SQLLevel=1

DBI模块是否提供Teradata接口?请使用DBD::Teradata模块。 - Rahul
我尝试过了,但是那个模块对于我的Teradata版本已经过时了。它给我一个关于废弃的登录凭据的错误。 - SemperFly
好的,我刚刚谷歌了一下,发现几乎每个人都没有成功地使用DBI或DBD::ODBC来连接Teradata。我还可以建议您尝试使用随附Teradata客户端的Teradata ODBC驱动程序,并查看是否可以通过它进行连接。 - Rahul
你正在使用哪个版本的DBD::ODBC以及哪个ODBC驱动程序管理器? - bohica
3个回答

4

我已经尝试连接该模块;我将附加脚本和错误消息。 - SemperFly

1

$ip 不能是一个 IP 地址。它需要是一个已知于你的 ODBC 驱动管理器的 ODBC 数据源的名称。我们需要知道你的驱动管理器以便提供更进一步的帮助。假设它是 unixODBC,你将会有一个 odbcinst.ini 文件,Teradata 驱动程序需要在其中命名,并且有一行指向驱动程序共享对象。然后在 odbc.ini 文件中创建一个数据源。


昨天我解决了这个问题。我在我的帖子中添加了额外的信息。 - SemperFly
我猜(从那些ini文件中),你正在使用iODBC驱动管理器?这方面不是我的专长,因为我使用的是unixODBC。不过,根据你的文件,我会说"tdsn"是正确的DSN,所以DBI字符串需要设为"dbi:ODBC:tdsn"。如果这行不通,设置并导出DBI_TRACE=15=x.log,并在连接调用前添加"DBI->trace(DBD::ODBC->parse_trace_flags('odbcconnection|odbcunicode'));"。我们来看看运行代码后x.log里有什么内容。 - bohica

1

我相信你已经找到了答案,但为了其他需要的人,我还是会发布一下:

odbcinst.ini:

[Teradata Database ODBC Driver 16.20]
Description=Teradata Database ODBC Driver 16.20
Driver=/opt/teradata/client/16.20/odbc_64/lib/tdataodbc_sb64.so
# Note: Currently, Data Direct Driver Manager does not support Connection Pooling feature.
CPTimeout=60

odbc.ini:

[ODBC Data Sources]
16.10=Teradata Database ODBC Driver 16.20
15.10=Teradata Database ODBC Driver 16.20
13.00=Teradata Database ODBC Driver 16.20
13.10=Teradata Database ODBC Driver 16.20
14.00=Teradata Database ODBC Driver 16.20

请注意数据源的名称可以是任何内容,我在此选择了版本。

Perl代码:

use DBD::ODBC;

my $conn = DBI->connect("DBI:ODBC:14.00",$username,$password);
#note how I'm connecting to the data source 14.00

my $create_user = $conn->prepare("CREATE USER $db_user from $username as perm = $perm, 
                                                password = XXXXXX,
                                                spool = $spool,
                                                NO fallback protection,
                                                default database = $db_user,
                                                NO after journal");
my $status = $create_user->execute();
$conn->disconnect();

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接