解決Emoji儲存MySQL報錯問題

來源:互聯網
上載者:User

標籤:group   mysql   set   com   有一個   儲存   style   nic   為什麼   

在解決之前,得先說明一下為什麼會出現報錯,Emoji表情佔用4個位元組,但是MySQL資料庫UTF-8編碼最多隻能儲存3個位元組,就會導致儲存不進去

如何解決Emoji儲存問題

mysql 的 utf8編碼的一個字元最多3個位元組,但是一個emoji表情為4個位元組,所以utf8不支援儲存emoji表情。但是utf8的超集utf8mb4一個字元最多能有4位元組,所以能支援emoji表情的儲存。但是修改這個配置太繁瑣了,容易出錯,emoji-java這個庫可以在程式碼片段解決這個問題,解決思路:

  • 頁面有一個表情??,在經過處理之後可以是??,將這個字元存入資料庫
  • 讀取的時候可以將??這個字元轉為??

例如: ?? 我可以儲存為:smile:,??儲存為:cry:,等等,可以這樣映射起來。

1、引入依賴
1 <dependency>2      <groupId>com.vdurmont</groupId>3      <artifactId>emoji-java</artifactId>4     <version>3.2.0</version>5 </dependency>
2、用法
String nikeNameTmp = resultjson.get("nickName").toString();String nikeName = EmojiParser.parseToAliases(nikeNameTmp); //將Emoji轉為字元

使用下面的兩個方法就可以互相轉換了:

EmojiParser.parseToAliases(string); 將Emoji轉為字元

EmojiParser.parseToUnicode(string); 將字元轉為Emoji

 

解決Emoji儲存MySQL報錯問題

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.