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; # 取出数据(同时记住不是NULL的项目) @{ $t{one} } = $$pref{dbh}->selectrow_array("SELECT * FROM $$pref{table} WHERE id = $$pref{oldid}");