本文目錄一覽:
php向mysql插入數據出錯
mysql語句在執行insert,update時,對於非數字的值,必須加引號,比如
1update tablename set attrA=’valueA’1update tablename set attrA=valueA;
這樣就會報錯。對於數字的值,可以不加,加上也不會影響插入效果,比如
1update tablename set intAttrA = 1;1update tablename set intAttrA = ‘1’;
這兩種都是可以的。
你這裡報錯的一行代碼,假設輸入的$_POST[‘username’]
=
『a』;$_POST[‘pwd’]
=
『b』;$_POST[‘content’]
=
‘c’;
在處理後,最後執行的是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(a,
b,
c);
它的錯誤就是上面說的非數字類的值,沒帶引號。
但實際上,正確的語句應該是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(『a』,
『b』,
『c』);
所以你測試的
$query
=
‘INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(“username”,
“pwd”,
“content”)’;
能正確執行。
最後問題的解決方法是:
1234567$query = “INSERT INTO userinfo (username, pwd, content) VALUES (‘”.$_POST[‘username’].”‘, ‘”.$_POST[‘pwd’].”‘, ‘”.$_POST[‘content’].”)”; 另外 為了看起來舒服點,可以這麼寫:$query = sprintf(“INSERT INTO userinfo (username, pwd, content) VALUES (‘%s’, ‘%s’, ‘%s);”,$_POST[‘username’],$_POST[‘pwd’],$_POST[‘content’]); 最後,你這種寫法,有Sql注入的風險,從安全形度來講是不可取的。所以應該這麼寫:$query = sprintf(“INSERT INTO userinfo (username, pwd, content) VALUES (unhex(‘%s’),unhex(‘%s’), unhex(‘%s’));”,bin2hex($_POST[‘username’]),bin2hex($_POST[‘pwd’]),bin2hex($_POST[‘content’]));
PHP插入mysql數據問題
這個報錯的含義是輸入的長度和Mysql設置的欄位長度不符,如果直接執行能成功那可以看看是不是編碼的問題.
php插入數據到MYSQL中出錯,怎麼正確插入
① 首先把MySQL的服務停掉 在運行窗口輸入:net stop mysql
② 把伺服器和客戶端的字符集改成自己想用的字符集:GB2312或是utf8等……
具體操作為:打開mysql安裝目錄下的myini.tet;
找到default-character-set,將其改為自己想用的字符集:GB2312或是utf8等……,要注意的是這裡有兩個default-character-set,用ctrl+f定位在文件最前面輸入default就會找到,都要改過來;
③ 重啟MySQL伺服器,在運行窗口輸入:net start mysql
④ 最重要的是一點是,到這裡我們已經能夠解決亂碼問題了,可問題是我們依然還會出現亂碼問題,這是因為我們現在的表被創建的時候用的是默認的字符集(latin1),所以這時候我們要把表刪除,然後重建就可以了
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/305271.html