最先試一試最簡單的測試方式就是先修改my.ini文件中的-default-character-set = gb2312或utf8,重啟mysql再輸入數據,如果不行,再考慮以下辦法。
在程序中寫了一段代碼向數據庫中插入數據,出現了data too long for column 'name' at row 1的問題。在google搜了一下解決方法,真是五花八門,也逐一試了一遍,終於終於將問題解決了。
下面先貼一下網上的眾多解決
1、修改my.ini文件:
將sql-mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION注釋掉,ok!
2、修改數據庫編碼為utf8,jsp,servlet編碼轉換為utf8存入
3、只知道是中文處理的問題,但不知道如何改.最好的方法是把字段定得長一些
4、把mysql的字符集設為utf8(通過修改my.ini,把所有的latin1改為utf8)並且通過show variables like '%char%'; 5、以前我也遇到過類似的情況,我的建議: 在裝數據庫的時候把你的字符集設置為gb2312,然后你建表的時候,漢字默認都是gb2312在連接數據庫的時候不要寫成characterEnconding=true&charset=gb2312,把這個去掉。然后在連接的時候寫c最好用gbk,gb2312對某些不常見的字符會出現Data too long for column,比如“珺”字等,至於數據庫,只有默認的字符集是gb2312或者gbk或者utf8都沒什么問題
對於我這里的情況也簡要描述下,我的mysql把server端,client端,connection的字符設置都為gbk,在控制太插入中文字沒有問題,但是從程序里面插入中文字就存在問題了。
用第一種方法試了下,不行。
用將所有的編碼格式改為utf8,以前數據庫里面的中文字全變成了亂碼,第二種方法也不行
第3種方法,我將數據庫里面的name設為varchar(255)這是足夠大的,可以存125個漢字了,還是不行,即使是存一個漢字也會報Data too long for column的錯誤,因此第3種方法顯然是瞎掰。
用第四種方法試了下,也這是提供你信息,你的數據庫各個端都采用什么編碼方式,並不能解決問題
最后試了第五種方法,沒有完全按照它所說的做,在插入數據庫之前先執行stat.execute("set names gb2312");就能成功將中文字插入到數據庫中。
這是為什么了?在采用第四種方式時,得到這樣的信息 +--------------------------+---------------------------------------------------- -----+ | Variable_name | Value | +--------------------------+---------------------------------------------------- -----+ |
character_set_client | gbk | | character_set_connection | gbk | | character_set_database | gbk | | character_set_results | gbk | | character_set_server | gbk | | character_set_system | utf8 | | character_sets_dir | C:\Program Files\MySQL\MySQL Server 5.0\share\chars ets\ | +--------------------------+---------------------------------------------------- 說明我的系統編碼方式與數據庫的編碼方式不符,用stat.execute("set names gb2312");將編碼方式先改為gb2312方式,就可以解決這樣的問題。