1064錯誤意思是說我的SQL語法錯誤,然後顯示錯誤的具體位置。
查看待更新的內容,以及執行跟新的php語句。
php語句如下:
if(!$handle= @fopen($fname, "r")) {echo "open $fname failed\n";exit;}; $str="";$count=0; $ins="INSERT INTO pydot_g (id, aauthor) VALUES"; while(($buf=fgets($handle, 1000)) !== false){ list($id,$field) = explode("#",$buf); $str .= sprintf('(%d,'%s'),',$id,$field); $count++; } $str.="(3955,'3955')"; $dup="ON DUPLICATE KEY UPDATE aauthor=VALUES(aauthor);"; $sql=$ins.$str.$dup; //echo $sql."\n"; if(!mysql_query($sql)) {echo "mysql failed\n"; echo mysql_errno() . ": " . mysql_error() . "\n";} fclose($handle); mysql_close($link);
待跟新的內容如下:
1320#CarryDream Int'l Co., Ltd. 1321#ES APP Group 1322#app4uu從中可以發現待跟新的內容中還有單引號“‘”,使用的sql語句中打印的字段也含有單引號,兩者產生了沖突。
所以解決的辦法就是,將sql中的語句改為使用雙引號““”,至此問題得以解決。