【发布时间】:2015-07-17 15:54:22
【问题描述】:
我不熟悉在 perl 脚本中使用 DBI 进行 SQL 查询。我遇到的问题与具有正斜杠的字段中的数据有关。我想使用变量作为 where 子句的输入,但它正在做 DBI 打算用正斜杠做的事情:停止查询。我尝试了许多不同的解决方法,包括绑定、引号等,但都没有奏效,甚至可能吗?这方面的数据是一致的。有 my $sql 变量的那一行是问题所在。
#!/usr/bin/perl
# Modules
use DBI;
use DBD::Oracle;
use strict;
use warnings;
# Connection Info
$platform = "Oracle";
$database = "mydb";
$user = "user";
$pw = "pass";
# Data Source
$ds = "dbi:Oracle:$database";
my $dbh = DBI->connect($ds, $user, $pw);
# my $dbh = DBI->connect();
my $XCOD = $dbh->quote('cba');
my $a = $dbh->quote('abc');
my $b = $dbh->quote('123');
# tried this as well my $pid = $dbh->quote('$a/$b');
my $sql = "SELECT P_ID FROM MyTable WHERE P_ID=$a/$b AND XCOD=$XCOD";
my $sth = $dbh->prepare($sql);
$sth->execute();
my $outfile = 'superunique.txt';
open OUTFILE, '>', $outfile or die "Unable to open $outfile: $!";
while(my @re = $sth->fetchrow_array) {
print OUTFILE @re,"\n";
}
close OUTFILE;
$sth->finish();
$dbh->disconnect();
【问题讨论】:
-
你试过
my $pid = $dbh->quote("$a/$b");,所以插值真的发生了吗? -
我没有;但是,它对我没有帮助。图我需要一个像 P_ID='abc/123' 这样的值,这意味着这样做时正斜杠不会包含在单个刻度中。
-
你能澄清一下吗?或许可以举个例子说明你是如何使用绑定变量来尝试的?