perl 学习资料整理篇第1/4页
2020-06-04 20:28:01
供稿:网友
 
NULL值的判断 
$t{type1id} = $$pref{dbh}->selectrow_array("SELECT type1id FROM enq1 WHERE id = 
3"); 
if ( $t{type1id} == 0 ) { 
print "Type1id is NULL/n"; 
} 
==>不是数值项的话,这个语句有问题。数值项专用。 
if ( length($t{type1id}) == 0 ) { 
print "Type1id is NULL/n"; 
} 
==>如果Null的话,这个语句有问题 
如果@rec含有NULL的话,下面的操作要出错误信息 
$t{line1} = join(' ',@rec); 
($t{old1},$t{new1p},$t{new1q}) = $self->dbh->selectrow_array("SELECT 
type1id,partsid,QTY FROM enq1 WHERE id = $t{enq1_id}"); 
91==> if ( $t{old1} == 0 ) { 
-------------------------------------------------- 
[error] [client 127.0.0.1] Use of uninitialized value in numeric eq (==) at 
./pro/mscenq1.pl line 91, <CONFIG> line 11., 
-------------------------------------------------- 
如何判断一个项目的值是否是NULL(未解决) 
解决!第一次INSERT时,放一个常数(比如"B") 
起源==> 
637==> $t{Nu1} = $self->dbh->selectrow_array("select parts_Unit from parts_nu 
where id = $t{Nuid1}"); 
-------------------------------------------------- 
[Wed May 14 17:27:51 2008] [error] [client 127.0.0.1] DBD::mysql::db 
selectrow_array failed: You have an error in your SQL syntax; check the manual 
that corresponds to your MySQL server version for the right syntax to use near 
'' at line 1 at ./pro/mscenq1.pl line 637, <CONFIG> line 11., referer: 
-------------------------------------------------- 
要考虑$t{Nuid1}不存在的情况 
考虑id=C的情况 
591==> 
@{ $t{p1} } = $self->dbh->selectrow_array("SELECT * FROM $t{ptable} 
WHERE id = $t{pid1}"); 
-------------------------------------------------- 
[error] [client 127.0.0.1] DBD::mysql::db selectrow_array failed: Unknown 
column 'C' in 'where clause' at ./pro/mscenq1.pl line 591, <CONFIG> line 11., 
referer: 
-------------------------------------------------- 
要考虑$t{pid1}='C'的情况 
if ( $#{ $t{pid_list} } == 0 && $t{pid_list}[0] eq 'C' ) { 
next; 
} 
COPY一个项目的subroutine 
use strict; 
use DBI; 
# 连接数据库 
my(%t,$n,@fld,@rec,$pref); 
print "This is test3.pl./n"; 
# 连接数据库 
$$pref{dsn} = "DBI:mysql:host=localhost;database=cookbook"; 
$$pref{dbh} = DBI->connect($$pref{dsn}, "cbuser", "cbpass") or die "Cannot 
connect to server/n"; 
$$pref{dbh}->do("SET NAMES utf8"); 
if(!$$pref{dbh}){ 
print "SQL read ERROR!/n"; 
exit; 
} 
$$pref{table} = 'enq2'; 
$$pref{oldid} = 4; 
($pref) = copy_one($pref); 
# 关闭数据库 
$$pref{dbh}->disconnect; 
# COPY一个项目 
sub copy_one { 
my($pref) = @_; 
my(%t,@rec,$n); 
# 取出COLUMNS 
$t{sth} = $$pref{dbh}->prepare("SHOW COLUMNS FROM $$pref{table}"); 
$t{sth}->execute; 
while ( @rec = $t{sth}->fetchrow_array ) { 
push(@{ $t{columns} },$rec[0]); 
} 
$t{sth}->finish;