- 论坛徽章:
- 0
|
小弟第一次接触perl,按照网上的例子执行下面的perl脚本,
提示在INSERT INTO address (id, name,email,telephone) VALUES (?, ?, ?, ?)});出错,
脚本全文如下:
#!/usr/bin/perl
use DBI;
#连接数据库mydata
my $dbh = DBI->connect('DBI:mysql:mydata') or die "无法连接数据库: " . DBI->errstr;
print "插入若干记录\n";
my $sth = $dbh->prepare(q{
INSERT INTO address (id, name,email,telephone) VALUES (?, ?, ?, ?)
});
print "输入记录,回车结束:";
while ($inputdata =<> {
chop $inputdata;
last unless($inputdata);
my ($id, $name,$email, $tel) = split( /,/, $inputdata);
$sth->execute($id, $name, $email,$tel)
}
# $dbh->commit;
print "下面根据输入的名字打印出EMAIL地址和电话\n";
my $sth = $dbh->prepare('SELECT * FROM address WHERE name=?')
or die $dbh->errstr;
print "请输入姓名,回车结束:";
while ($inputname =<> {
my @data;
chomp $inputname;
last unless($inputname);
$sth->execute($inputname) or die "错误: " . $sth->errstr;
while (@data = $sth->fetchrow_array()) {
print "Email data[2]\t Telephone data[3]\n";
}
}
#断开连接
$dbh->disconnect;
请各位高手帮忙解释一下:
1.那问号什么意思?为什么出错
2.该怎样解决?
万分感谢!! |
|