① 首先把MySQL的服務(wù)停掉 在運行窗口輸入:net stop mysql
成都創(chuàng)新互聯(lián)專注于豐寧企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),電子商務(wù)商城網(wǎng)站建設(shè)。豐寧網(wǎng)站建設(shè)公司,為豐寧等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站制作,專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
② 把服務(wù)器和客戶端的字符集改成自己想用的字符集:GB2312或是utf8等……
具體操作為:打開mysql安裝目錄下的myini.tet;
找到default-character-set,將其改為自己想用的字符集:GB2312或是utf8等……,要注意的是這里有兩個default-character-set,用ctrl+f定位在文件最前面輸入default就會找到,都要改過來;
③ 重啟MySQL服務(wù)器,在運行窗口輸入:net start mysql
④ 最重要的是一點是,到這里我們已經(jīng)能夠解決亂碼問題了,可問題是我們依然還會出現(xiàn)亂碼問題,這是因為我們現(xiàn)在的表被創(chuàng)建的時候用的是默認的字符集(latin1),所以這時候我們要把表刪除,然后重建就可以了
mysql語句在執(zhí)行insert,update時,對于非數(shù)字的值,必須加引號,比如
1update tablename set attrA='valueA'1update tablename set attrA=valueA;
這樣就會報錯。對于數(shù)字的值,可以不加,加上也不會影響插入效果,比如
1update tablename set intAttrA = 1;1update tablename set intAttrA = '1';
這兩種都是可以的。
你這里報錯的一行代碼,假設(shè)輸入的$_POST['username']
=
‘a(chǎn)’;$_POST['pwd']
=
‘b’;$_POST['content']
=
'c';
在處理后,最后執(zhí)行的是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(a,
b,
c);
它的錯誤就是上面說的非數(shù)字類的值,沒帶引號。
但實際上,正確的語句應(yīng)該是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(‘a(chǎn)’,
‘b’,
‘c’);
所以你測試的
$query
=
'INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
("username",
"pwd",
"content")';
能正確執(zhí)行。
最后問題的解決方法是:
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注入的風險,從安全角度來講是不可取的。所以應(yīng)該這么寫:$query = sprintf("INSERT INTO userinfo (username, pwd, content) VALUES (unhex('%s'),unhex('%s'), unhex('%s'));",bin2hex($_POST['username']),bin2hex($_POST['pwd']),bin2hex($_POST['content']));
你可以先在mysql里面執(zhí)行一遍sql語句,看下能不能添加數(shù)據(jù),先檢查語句有沒有問題,再看程序上的問題
這是因為你的數(shù)據(jù)庫連接方式是mysqli,不是mysql,所以:
mysql_query
要改為
mysqli_query
或者
$conn-query
你當前使用的用戶名沒有添加的權(quán)限,應(yīng)該給當前用戶分配權(quán)限,具體過程:
1.用最上位管理者登陸mysql,就是用戶名是root的那個
2.點擊主頁面上的【權(quán)限】按鈕,會出現(xiàn) 用戶一覽
3.在用戶一覽 頁面,選擇當前用戶名【hxm】進行 編輯權(quán)限,選擇【全選】就可以了
最后 重新登錄mysql
檢查你的mysql表設(shè)置的字段,字段類型,是否為空等是否與你插入的數(shù)據(jù)類型信息相符,如果插入失敗,數(shù)據(jù)庫應(yīng)該會報錯,你仔細查看一下報錯信息。