我用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)' )
在插入過程中出現以下warning :
Warning (Code 1366): Incorrect string value: 'xC2xCCxB9xE2xC9xAD...' for column 'msg' at row 1
查看插入後數據表,msg 字段中只有中文字符“綠光森林”前的部分插入,而其後內容被截斷了,插入字段落msg的內容如下:
smbd[45997]: xxxx opened file Public/pub/
這其實編碼問題,偶遇到的同事是吧編碼設置GB2312導致的,當涉及到一些特殊字符的時候,就會出現截斷的時候,就會報錯,轉變為“ ? ”進行顯示。
mysql錯誤:Warning: #1366 Incorrect string value:解決方法:
很簡單,將原來的編碼gb2312改為:gbk編碼,或者改為utf8編碼。
附上:GB2312和GBK編碼區別。
GB2312是中國規定的漢字編碼,也可以說是簡體中文的字符集編碼;GBK 是 GB2312的擴展 ,除了兼容GB2312外,它還能顯示繁體中文,還有日文的假名
經驗之談
建時選擇utf8字符集或者再把mysql數據庫表或數據庫字段或數據集修改成uft8即可解決了。