mysql 1064异常原因及解决方法
程序员文章站
2022-04-09 11:06:39
...
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语句。
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防注入代码
推荐阅读
-
phpmyadmin报错原因及解决办法:无法在发生异常时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装
-
Win7系统开机启动蓝屏出现0x00000069错误代码的原因及解决方法
-
Jquery Post处理后不进入回调的原因及解决方法教程
-
IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法_html/css_WEB-ITnose
-
Win10系统电脑无法登录LOL提示服务器连接异常的原因及解决方法
-
win10系统经常假死怎么办 Win10系统电脑经常假死机的原因及解决方法图文教程
-
win10系统设备管理器没有端口怎么办 win10设备管理器没有端口的多种原因及解决方法
-
mysql5.7更新操作报异常thisisincompatiblewithsql_mode=only_full_group_by的原因和解决办法
-
笔记本电脑电池无法充满电的可能原因及解决方法整理
-
遭遇ORA-01200错误的原因及解决方法