程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql1064錯誤原因及解決辦法

mysql1064錯誤原因及解決辦法

編輯:MySQL綜合教程

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中的語句改為使用雙引號““”,至此問題得以解決。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved