好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁(yè) > 知識(shí)庫(kù) > MySQL插入emoji表情失敗問(wèn)題的解決方法

MySQL插入emoji表情失敗問(wèn)題的解決方法

熱門(mén)標(biāo)簽:南宋地圖標(biāo)注黃河華山 電銷(xiāo)機(jī)器人公眾號(hào)推送 長(zhǎng)安區(qū)違法建房地圖標(biāo)注 地圖標(biāo)注培訓(xùn) 安國(guó)在哪里辦理400電話 電銷(xiāo)機(jī)器人說(shuō)明書(shū) 昆明智能外呼系統(tǒng)中心 手機(jī)用地圖標(biāo)注工具 智能電銷(xiāo)機(jī)器人靠譜么

前言

之前一直認(rèn)為UTF-8是萬(wàn)能的字符集問(wèn)題解決方案,直到最近遇到這個(gè)問(wèn)題。最近在做新浪微博的爬蟲(chóng), 在存庫(kù)的時(shí)候發(fā)現(xiàn)只要保持emoji表情,就回拋出以下異常:

Incorrect string value: '\xF0\x90\x8D\x83\xF0\x90...'

眾所周知UTF-8是3個(gè)字節(jié), 其中已經(jīng)包括我們?nèi)粘D芤?jiàn)過(guò)的絕大多數(shù)字體. 但3個(gè)字節(jié)遠(yuǎn)遠(yuǎn)不夠容納所有的文字, 所以便有了utf8mb4, utf8mb4是utf8的超集, 占4個(gè)字節(jié), 向下兼容utf8. 我們?nèi)粘S玫膃moji表情就是4個(gè)字節(jié)了.

所以在此我們像utf8的數(shù)據(jù)表插入數(shù)據(jù)就會(huì)報(bào)出Incorrect string value這個(gè)錯(cuò)誤.

Google一下很容易就找到了解決方案, 具體解決辦法是如下:

一、修改數(shù)據(jù)表的字符集為utf8mb4

這點(diǎn)很簡(jiǎn)單, 修改語(yǔ)句網(wǎng)上找一大堆, 不過(guò)建議重新建表, 使用 mysqldump -uusername -ppassword database_name table_name > table.sql 備份相應(yīng)數(shù)據(jù)表, 并修改其中的建表語(yǔ)句的字符集為 utf8mb4 即可, 然后 mysql -uusername -ppassword database_name table.sql 重新導(dǎo)入sql即可完成修改字符集操作.

二、MySQL數(shù)據(jù)庫(kù)版本要5.5.3及以上

網(wǎng)絡(luò)上所有的文章都說(shuō)明要MySQL 5.5.3以上的版本才支持utf8mb4, 不過(guò)我使用的數(shù)據(jù)庫(kù)版本為5.5.18, 最終仍能解決問(wèn)題, 所以同學(xué)們不要急著找運(yùn)維哥哥升級(jí)數(shù)據(jù)庫(kù)先, 先試試能不能自己解決問(wèn)題.

三、修改數(shù)據(jù)庫(kù)配置文件/etc/my.cnf并重啟mysql服務(wù)

主要是修改數(shù)據(jù)庫(kù)的默認(rèn)字符集, 以及連接, 查詢(xún)的字符集, [Mysql支持emoji 表情符號(hào) 升級(jí)編碼為UTF8MB4][1] 這篇文章有詳細(xì)的設(shè)置方法, [深入Mysql字符集設(shè)置][2] 這篇文章有其中設(shè)置的各個(gè)字符集的作用, 大家可以科普下.

四、升級(jí)MySQL Connector到5.1.21及以上

以上所有的操作, 最關(guān)鍵的是步驟3, 修改數(shù)據(jù)庫(kù)的配置文件, 其中大概修改了

[client]
# 客戶(hù)端來(lái)源數(shù)據(jù)的默認(rèn)字符集
default-character-set = utf8mb4
[mysqld]
# 服務(wù)端默認(rèn)字符集
character-set-server=utf8mb4
# 連接層默認(rèn)字符集
collation-server=utf8mb4_unicode_ci
[mysql]
# 數(shù)據(jù)庫(kù)默認(rèn)字符集
default-character-set = utf8mb4

這些配置指定了數(shù)據(jù)從客戶(hù)端到服務(wù)端所經(jīng)過(guò)的一條條管道使用的字符集, 其中每一個(gè)管道出現(xiàn)問(wèn)題都可能會(huì)導(dǎo)致插入失敗或者亂碼.

但很多時(shí)候, 線上的數(shù)據(jù)庫(kù)是不能隨便修改數(shù)據(jù)庫(kù)文件的, 所以我們的運(yùn)維同學(xué)很果斷的回絕了我修改數(shù)據(jù)庫(kù)配置文件的請(qǐng)求(T_T)

所以就只能用代碼解決了, 一開(kāi)始是準(zhǔn)備從JDBC連接時(shí)候就指定使用的字符集處下手.

jdbc:mysql://localhost:3306/ding?characterEncoding=UTF-8

主要把UTF-8修改為utf8mb4對(duì)于的Java Style Charset字符串應(yīng)該就能解決問(wèn)題吧?

不過(guò)很遺憾的是, Java JDBC并不存在utf8mb4對(duì)于的字符集. 使用UTF-8的時(shí)候可以兼容urf8mb4并自動(dòng)轉(zhuǎn)換字符集.

For example, to use 4-byte UTF-8 character sets with Connector/J, configure the MySQL server with character_set_server=utf8mb4, and leave characterEncoding out of the Connector/J connection string. Connector/J will then autodetect the UTF-8 setting. – [MySQL:Using Character Sets and Unicode][3]

后來(lái)科普了一下, 在每一次查詢(xún)請(qǐng)求的時(shí)候, 可以顯式的指定使用的字符集, 使用 set names utf8mb4 可以指定本次鏈接的字符集為utf8mb4, 但這個(gè)設(shè)置在每次連接被釋放后都會(huì)失效.

目前的解決辦法是, 在需要插入utf8mb4的時(shí)候, 顯示地調(diào)用執(zhí)行set names utf8mb4, 如:

jdbcTemplate.execute("set names utf8mb4");
jdbcTempalte.execute("...");

需要注意的是, 我們?cè)谑褂靡幌翺RM框架的時(shí)候, 因?yàn)樾阅軆?yōu)化原因, 框架會(huì)延遲提交, 除非事務(wù)結(jié)束或者用戶(hù)主動(dòng)調(diào)用強(qiáng)制提交, 負(fù)責(zé)執(zhí)行的set names utf8mb4仍然不會(huì)生效.

在這里我使用的是myBatis, 以MessageDao為例

// MessageDao
public interface MessageDao {
 @Update("set names utf8mb4")
 public void setCharsetToUtf8mb4();
 @Insert("insert into tb_message ......")
 public void insert(Message msg);
}
// test code
SqlSession sqlSession = sqlSessioFactory.openSession();
messageDao = sqlSession.getMapper(MessageDao.class);
messageDao.setCharsetToUtf8mb4();
// 強(qiáng)制提交
sqlSession.commit();
messageDao.insert(message);

至此, 問(wèn)題便解決了..

哎, 如果世事能那么順利就好了, 在項(xiàng)目中, mybatis是實(shí)例是交由Spring去管理的, 也就是說(shuō)我拿不到sqlSession, 也就是強(qiáng)制提交不了. 并且因?yàn)镾pring事務(wù)框架的限制, 他并不允許用戶(hù)顯式調(diào)用強(qiáng)制提交. 目前還在糾結(jié)這個(gè)問(wèn)題.

有兩個(gè)解決思路:

  • 使用AOP, 在可能插入4字節(jié)UTF8字符的時(shí)候, 前置方法執(zhí)行set names utf8mb4, 但該方案還不能確定AOP的方法會(huì)被Spring進(jìn)行事務(wù)管理么, 并且在前置方法中,拿到的鏈接是否和接下來(lái)拿到的連接對(duì)象是同一個(gè)session.
  • 研究Spring JDBC的創(chuàng)建方法, 寫(xiě)一個(gè)hook在每次創(chuàng)建新的數(shù)據(jù)庫(kù)連接的時(shí)候, 都執(zhí)行一次set names utf8mb4, 這樣就保證每一次拿到的鏈接都是設(shè)置過(guò)字符集的.

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,待有時(shí)間再實(shí)驗(yàn)一下以上兩種方案。希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • mysql存儲(chǔ)emoji表情步驟詳解
  • mysql中插入emoji表情失敗的原因與解決
  • MySQL無(wú)法存儲(chǔ)emoji表情解決方案分析
  • mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
  • MySQL無(wú)法存儲(chǔ)Emoji表情問(wèn)題的解決方法分析
  • 讓Java后臺(tái)MySQL數(shù)據(jù)庫(kù)能夠支持emoji表情的方法
  • 使MySQL能夠存儲(chǔ)emoji表情字符的設(shè)置教程
  • MySQL如何插入Emoji表情

標(biāo)簽:潛江 武漢 長(zhǎng)沙 東莞 合肥 南昌 江門(mén) 吉安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL插入emoji表情失敗問(wèn)題的解決方法》,本文關(guān)鍵詞  MySQL,插入,emoji,表情,失敗,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL插入emoji表情失敗問(wèn)題的解決方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于MySQL插入emoji表情失敗問(wèn)題的解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲国产成人精品无码区在线美香 | 欧美成人精品久久精品| 国产无遮挡A片又黄又爽小直播 | 车内强摁做开腿呻吟H| 影音先锋成人资源AV在线观看| 国产黄色小视频网站| 女性隐私免费观看视频| 巨胸大乳寂寞人妻电影| 《美国式禁忌3》电影| 撅着屁股挨打sp调教故事| 调教局长夫妇奴| 用力?别停?受不了绿帽| 日日躁夜夜躁狠狠天天| 无翼乌电车痴汉乃梨子剧情简介| 91在线无码精品秘?国产苹果| 放荡性漫画全文免费| 欧美黑人xxxx猛牲大交| 王爷攻×暗卫受r18肉| 国产成人网| 天堂资源地址在线| 久久精品AV无码专区| 将她双腿分得更开| 萌白酱一区| 91看片淫黄大片在看| 国产精品爱啪在线线免费观看| 最近的免费中文字幕视频 | 欧美国产日韩1区俺去了| 色戒在线未删减完整版播放| 中文字幕一区二区三区乱码在线 | 色欲av人妻精品一区二区 | 欧美换爱交换乱理伦片禁忌| 黄色伦理片| 小黄文细节| 无遮挡一级婬妇片A片AAA毛片| 欧美狠狠操| 香港三级巜欲性高蜜桃成熟时类似| 扒开内裤边吃奶XXOO| 黄色一片级| 色戒五场床戏在几分几秒| 美女裸体啪啪到高潮无遮挡 | 少妇激情婬乱1一13美国手机免费的|