【发布时间】:2018-12-10 06:35:05
【问题描述】:
我有 MYSQL 数据库,其字段名称包含连字符。尝试使用 Perl 将数据从 XML 插入数据库。我在 %HEAD 中有 XML 键是列标题,值是对应的数据。
my %HEAD= ('REGISTRATION-NUMBER' => 'AAACT2727QXM003',
'RETURN-YEAR' => '2013',
'MONTH' => 'July',
'LTU' => 'Yes',
'NIL-RETURN' => 'No',
'ASSESSEE-NAME' => 'TATA MOTORS LIMITED');
my @HEADER_keys= keys %HEAD;
foreach $key(@HEADER_keys) {
$value= $HEAD{$key};
my $sth = $dbh->prepare("INSERT INTO indirect_taxes($key) VALUES ($value)");
$sth->execute() or die $sth->errstr;
}
或者代替foreach
my @HEADER_values= values %HEAD;
my $sth = $dbh->prepare("INSERT INTO indirect_taxes(?) VALUES (?)");
$sth->execute_array(\@HEADER_keys, \@HEADER_values) or die "the failure cause: $DBI::errstr";
由于键包含连字符,我收到 MYSQL 语法错误。来自Can a table field contain a hyphen?
获得语法但使用 perl 无法将反引号添加到变量 $key 或 @HEADER_keys。
请建议一种在 $keys 中添加反引号的方法。
【问题讨论】:
-
我对 Perl 一无所知,但我认为您应该编辑您的问题并解释究竟是什么阻止了您添加反引号。您是否需要保留未引用的名称以用于其他用途?
-
您应该使用placeholders 而不是插值变量。
-
@Alvaro 在 perl 反引号中执行命令,命令完成后继续执行 perl 脚本。
-
@mudBorn - 即使在字符串中?好吧,我说的很明显:我对 Perl xD 一无所知
-
@ÁlvaroG.Vicario:没有。