mysql 问题排查1064_mysql1064异常原因及解决方法

mysql 1064错误原因及解决办法 1064错误意思是说我的SQL语法错误,然后显示错误的具体位置。 查看待更新的内容,以及执行跟新的php语句。 php语句如下: if(!$handle= @fopen($fname, r)) {echo open $fname failed\n;exit;}; $str=;$count=0;$ins=INSERT INT

mysql 1064错误原因及解决办法

1064错误意思是说我的SQL语法错误,然后显示错误的具体位置。

查看待更新的内容,以及执行跟新的php语句。

094504357.jpg

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中的语句改为使用双引号““”,至此问题得以解决。

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值