mysql錯誤:Warning: #1366 Incorrect string value:?誤主要是因為編碼問題了,如你gb2312的編碼中如果有繁體字就會提示這類錯誤了,所以導致這問題是編碼范圍問題.
我用mysql記錄syslog-ng的日志信息,分解后把日志插入MYSQL,INSERT語句如下:
INSERT?INTO?logs(host,?facility,?priority,?level,?tag,?datetime,?program,?msg)?
?
VALUES?(?'phy',?'daemon',?'notice',?'notice',?'1d',?'2008-07-30?12:24:12','smbd',?'smbd[45997]:???xxxx?opened?file?Public/pub/綠光森?DVD13.rmvb?read=Yes?write=No?(numopen=14)'?)?
在插入過程中出現(xiàn)以下warning:Warning (Code 1366): Incorrect string value: 'xC2xCCxB9xE2xC9xAD...' for column 'msg' at row 1 //phpfensi.com
查看插入后數(shù)據(jù)表,msg 字段中只有中文字符“綠光森林”前的部分插入,而其后內(nèi)容被截斷了,插入字段落msg的內(nèi)容如下:
smbd[45997]: xxxx opened file Public/pub/
這其實編碼問題,偶遇到的同事是吧編碼設(shè)置GB2312導致的,當涉及到一些特殊字符的時候,就會出現(xiàn)截斷的時候,就會報錯,轉(zhuǎn)變?yōu)椤??? ?”進行顯示.
mysql錯誤:Warning: #1366 Incorrect string value:解決方法,很簡單,將原來的編碼gb2312改為:gbk編碼,或者改為utf8編碼.
附上:GB2312和GBK編碼區(qū)別.
GB2312是中國規(guī)定的漢字編碼,也可以說是簡體中文的字符集編碼;GBK 是 GB2312的擴展,除了兼容GB2312外,它還能顯示繁體中文,還有日文的假名.
經(jīng)驗之談:建時選擇utf8字符集或者再把mysql數(shù)據(jù)庫表或數(shù)據(jù)庫字段或數(shù)據(jù)集修改成uft8即可解決了.