PHP無法寫进mySQL
程序员文章站
2022-06-16 18:23:21
...
PHP無法寫入mySQL
小妹是php新手
最近想要試著寫一個搜尋程式
主要是藉由php作為媒介連結android和mySQL
不過卻卡在我的php一直無法成功判讀SQL語法
以下是我主要問題程式片段:
(in java)
try {
String result = DBConnector.executeQuery("SELECT*FROM user where zip = 'newzip' ");
System.out.println(result);
(php語法)
$db = mysql_pconnect("localhost","root","1234");
mysql_query("SET CHARACTER SET 'UTF8';");
mysql_query("SET NAMES UTF8;");
mysql_query("SET CHARACTER_SET_CLIENT=UTF8;");
mysql_query("SET CHARACTER_SET_RESULTS=UTF8;");
mysql_select_db("food");
$sql = $_POST["query_string"];
$res = mysql_query($sql);
while($r = mysql_fetch_assoc($res))
$output[] = $r;
print(json_encode($output));
mysql_close();
?>
這是我的錯誤訊息:
mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in C:\AppServ\www\AndroidConnectDB\android_connect_db.php on line 13
我有將java中的語法直接在phpmyadmin中執行
(即SELECT*FROM user where zip = 'newzip')
是可以正確找到該筆符合條件的資料
但是不知道為什麼 透過java寫入至php中去呼叫mySQL執行時卻總是傳回錯誤
上網爬過很多文
有試著去修正過編碼的問題(SET NAMES UTF8;)
也有去php.ini修改過 magic_quotes_gpc = On
但仍舊回傳null以及錯誤訊息
但是我將它改成
SELECT*FROM user where id=1 時
是可以正確執行的00"
所以再猜想會不會是單引號引起的問題
也有將它改成
SELECT*FROM user where zip = /'newzip/'
卻仍舊不見好轉ˊˋ
想要請問各位大大是否有解決的方法?ˊˋ
------解决方案--------------------
猜测是没有用的,需要看到出错时的错误信息
$res = mysql_query($sql) or die(mysql_error());
因为你给出的错误信息是
mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource
即传递给 mysql_fetch_assoc 的不是有效的 MySQL 资源,所以要逐步向上查找
------解决方案--------------------
你不觉得应该是这样吗?
------解决方案--------------------
关闭魔术引号,修改php.ini magic_quotes_gpc = Off
或者临时对传入字符串反转义
小妹是php新手
最近想要試著寫一個搜尋程式
主要是藉由php作為媒介連結android和mySQL
不過卻卡在我的php一直無法成功判讀SQL語法
以下是我主要問題程式片段:
(in java)
try {
String result = DBConnector.executeQuery("SELECT*FROM user where zip = 'newzip' ");
System.out.println(result);
(php語法)
$db = mysql_pconnect("localhost","root","1234");
mysql_query("SET CHARACTER SET 'UTF8';");
mysql_query("SET NAMES UTF8;");
mysql_query("SET CHARACTER_SET_CLIENT=UTF8;");
mysql_query("SET CHARACTER_SET_RESULTS=UTF8;");
mysql_select_db("food");
$sql = $_POST["query_string"];
$res = mysql_query($sql);
while($r = mysql_fetch_assoc($res))
$output[] = $r;
print(json_encode($output));
mysql_close();
?>
這是我的錯誤訊息:
mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in C:\AppServ\www\AndroidConnectDB\android_connect_db.php on line 13
我有將java中的語法直接在phpmyadmin中執行
(即SELECT*FROM user where zip = 'newzip')
是可以正確找到該筆符合條件的資料
但是不知道為什麼 透過java寫入至php中去呼叫mySQL執行時卻總是傳回錯誤
上網爬過很多文
有試著去修正過編碼的問題(SET NAMES UTF8;)
也有去php.ini修改過 magic_quotes_gpc = On
但仍舊回傳null以及錯誤訊息
但是我將它改成
SELECT*FROM user where id=1 時
是可以正確執行的00"
所以再猜想會不會是單引號引起的問題
也有將它改成
SELECT*FROM user where zip = /'newzip/'
卻仍舊不見好轉ˊˋ
想要請問各位大大是否有解決的方法?ˊˋ
------解决方案--------------------
猜测是没有用的,需要看到出错时的错误信息
$res = mysql_query($sql) or die(mysql_error());
因为你给出的错误信息是
mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource
即传递给 mysql_fetch_assoc 的不是有效的 MySQL 资源,所以要逐步向上查找
------解决方案--------------------
你不觉得应该是这样吗?
SELECT * FROM user where zip = 'newzip'
------解决方案--------------------
关闭魔术引号,修改php.ini magic_quotes_gpc = Off
或者临时对传入字符串反转义
$sql = stripslashes($_POST["query_string"]);也可以应付过来
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
上一篇: ie6下 js加载有关问题
下一篇: 实例讲解PHP面向对象之多态
推荐阅读
-
CentOS 7.0编译安装Nginx1.6.0+MySQL5.6.19+PHP5.5.14方法分享
-
PHP無法寫进mySQL
-
php file_get_contents 無法顯示圖片
-
最纯净的Apache 2 && PHP 5 && Mysql 5 for WinXP配置法
-
张进杰-php while条件为真循环 结合mysql输出html数据
-
PHP?法?入mySQL
-
CentOS 7.0编译安装Nginx1.6.0+MySQL5.6.19+PHP5.5.14方法分享
-
最纯净的Apache 2 && PHP 5 && Mysql 5 for WinXP配置法
-
张进杰-php while条件为真循环 结合mysql输出html数据
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论