解決data too long for column 'name' at row 1


最先試一試最簡單的測試方式就是先修改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方式,就可以解決這樣的問題。 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM