校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】

mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】

熱門標簽:陜西400電話如何申請 地圖標注賺錢真假 合肥營銷外呼系統收費 承德電腦地圖標注 德惠市地圖標注 商家地圖標注哪個好 外呼系統從哪買 深圳 遵義地圖標注app

本文實例分析了mysql存儲emoji表情報錯的處理方法。分享給大家供大家參考,具體如下:

utf-8編碼可能2個字節、3個字節、4個字節的字符,但是MySQL的utf8編碼只支持3字節的數據,而移動端的表情數據是4個字節的字符。如果直接往采用utf-8編碼的數據庫中插入表情數據,Java程序中將報SQL異常:

java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'name' at row 1
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)

可以對4字節的字符進行編碼存儲,然后取出來的時候,再進行解碼。但是這樣做會使得任何使用該字符的地方都要進行編碼與解碼。

utf8mb4編碼是utf8編碼的超集,兼容utf8,并且能存儲4字節的表情字符。
采用utf8mb4編碼的好處是:存儲與獲取數據的時候,不用再考慮表情字符的編碼與解碼問題

更改數據庫的編碼為utf8mb4:

1. MySQL的版本

utf8mb4的最低mysql版本支持版本為5.5.3+,若不是,請升級到較新版本。

2. MySQL驅動

5.1.34可用,最低不能低于5.1.13

3.修改MySQL配置文件

修改mysql配置文件my.cnf(windows為my.ini)

my.cnf一般在etc/mysql/my.cnf位置。找到后請在以下三部分里添加如下內容:

[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'

4. 重啟數據庫,檢查變量

復制代碼 代碼如下:
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

Variable_name Value
character_set_client utf8mb4
character_set_connection utf8mb4
character_set_database utf8mb4
character_set_filesystem binary
character_set_results utf8mb4
character_set_server utf8mb4
character_set_system utf8
collation_connection utf8mb4_unicode_ci
collation_database utf8mb4_unicode_ci
collation_server utf8mb4_unicode_ci

collation_connection 、collation_database 、collation_server是什么沒關系。

但必須保證

系統變量 描述
character_set_client (客戶端來源數據使用的字符集)
character_set_connection (連接層字符集)
character_set_database (當前選中數據庫的默認字符集)
character_set_results (查詢結果字符集)
character_set_server (默認的內部操作字符集)

這幾個變量必須是utf8mb4。

5. 數據庫連接的配置

數據庫連接參數中:

characterEncoding=utf8會被自動識別為utf8mb4,也可以不加這個參數,會自動檢測。

autoReconnect=true是必須加上的。

6. 將數據庫和已經建好的表也轉換成utf8mb4

更改數據庫編碼:

復制代碼 代碼如下:
ALTER DATABASE caitu99 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

更改表編碼:

復制代碼 代碼如下:
ALTER TABLE TABLE_NAME CONVERT TO CHARACTER SET utf8mb4 COLLATEutf8mb4_general_ci;

如有必要,還可以更改列的編碼

7、在第3步設置character_set_database,character_set_server不成功的可以試下直接在mysql.exe下

set @@character_set_server='utf8mb4';
set @@character_set_database='utf8mb4';

這下數據庫就可以存下emoji表情的編碼了。

附上我的my.ini

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html
# *** DO NOT EDIT THIS FILE. It's a template which will be copied to the
# *** default location during install, and will be replaced if you
# *** upgrade to a newer version of MySQL.
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
# These are commonly set, remove the # and set as required.
# basedir = .....
# datadir = .....
# port = .....
# server_id = .....
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL存儲過程技巧大全》、《MySQL常用函數大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》及《MySQL數據庫鎖相關技巧匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • emoji表情與unicode編碼互轉的實現(JS,JAVA,C#)

標簽:南陽 三門峽 商丘 貴州 巴中 揚州 新余 贛州

巨人網絡通訊聲明:本文標題《mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】》,本文關鍵詞  mysql,存儲,emoji,表,情報,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】》相關的同類信息!
  • 本頁收集關于mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    av中文一区二区三区| 99久久777色| 日韩和欧美一区二区| 亚洲免费视频中文字幕| 亚洲欧美在线视频| 亚洲欧美经典视频| 亚洲精品视频在线| 亚洲成a人片在线不卡一二三区 | 1024国产精品| 中文字幕日本乱码精品影院| 亚洲丝袜自拍清纯另类| 亚洲精品免费视频| 亚洲成人先锋电影| 韩国一区二区视频| 久久97超碰色| 99国产精品久| 欧美一区二区精品在线| 精品成a人在线观看| 中文字幕av一区二区三区高| 亚洲尤物视频在线| 美女视频黄 久久| 国产成人激情av| 91看片淫黄大片一级在线观看| 在线国产电影不卡| 欧美大片一区二区三区| 国产亚洲一区二区在线观看| 日韩理论片在线| 日本怡春院一区二区| 国产精品18久久久久久久久| 91老师国产黑色丝袜在线| 欧美精品丝袜中出| 国产偷国产偷亚洲高清人白洁| 亚洲欧洲日韩在线| 日本欧美加勒比视频| 国产成人精品亚洲日本在线桃色| 色婷婷久久久综合中文字幕| 日韩欧美黄色影院| 亚洲激情自拍视频| 国产成人免费在线观看不卡| 欧美羞羞免费网站| 久久精品日产第一区二区三区高清版 | 欧美日韩国产bt| 国产欧美视频一区二区| 石原莉奈一区二区三区在线观看| 成人免费黄色大片| 日韩欧美一区二区三区在线| 一区二区激情小说| 成人av先锋影音| 久久久精品2019中文字幕之3| 亚洲高清一区二区三区| 成人高清在线视频| 国产网站一区二区| 麻豆中文一区二区| 欧美日韩国产精品自在自线| 一区二区三区四区蜜桃| 成人激情校园春色| 国产欧美日韩在线观看| 精品一区二区精品| 日韩一区和二区| 日韩高清在线电影| 制服丝袜av成人在线看| 亚洲国产日韩精品| 在线观看一区二区精品视频| 亚洲视频网在线直播| 精品一区二区久久久| 日韩欧美在线网站| 全部av―极品视觉盛宴亚洲| 欧美猛男gaygay网站| 亚洲尤物在线视频观看| 欧美性大战久久| 亚洲美女免费视频| 色欲综合视频天天天| 亚洲人亚洲人成电影网站色| 99久久综合色| 亚洲人成网站精品片在线观看| 成人一区二区三区视频在线观看| 精品动漫一区二区三区在线观看| 美女视频一区二区三区| 精品日韩一区二区| 国产剧情一区在线| 欧美国产一区二区| 99精品国产视频| 亚洲精品免费在线| 91精品国产综合久久久久| 麻豆一区二区在线| 国产日韩欧美高清在线| 99国内精品久久| 亚洲丝袜制服诱惑| 在线不卡a资源高清| 久久精品国产一区二区三| 国产欧美精品在线观看| 色综合久久综合网97色综合| 亚洲第一精品在线| 久久综合久久鬼色中文字| 成人免费福利片| 亚洲妇熟xx妇色黄| 欧美xxxxx牲另类人与| 成人免费的视频| 亚洲无人区一区| 欧美精品一区男女天堂| 99视频在线观看一区三区| 亚洲午夜成aⅴ人片| 精品理论电影在线观看| 成人高清免费在线播放| 亚洲一二三区在线观看| 精品国产免费久久| 色综合一个色综合亚洲| 九一九一国产精品| 一区二区三区波多野结衣在线观看| 欧美一三区三区四区免费在线看| 国产黄色91视频| 亚洲成人你懂的| 国产精品丝袜久久久久久app| 欧美私人免费视频| 国产成人免费av在线| 亚洲电影视频在线| 中文字幕第一页久久| 91精品国产一区二区三区| 色屁屁一区二区| 久久综合一区二区| 99久精品国产| 久久99精品国产.久久久久| 亚洲精品免费在线| 欧美成人一区二区| 在线观看日韩一区| 夫妻av一区二区| 免费三级欧美电影| 亚洲国产日韩a在线播放| 国产精品黄色在线观看| 欧美一级久久久久久久大片| 日本道色综合久久| av午夜精品一区二区三区| 国产米奇在线777精品观看| 日韩精品欧美成人高清一区二区| 1000部国产精品成人观看| 久久一区二区视频| 日韩欧美专区在线| 制服.丝袜.亚洲.另类.中文| 欧美伊人久久大香线蕉综合69| 99久久国产综合精品麻豆| 国产91精品一区二区麻豆网站| 久久精品国产色蜜蜜麻豆| 青青草国产精品97视觉盛宴| 午夜a成v人精品| 天天色天天爱天天射综合| 午夜精品在线看| 五月激情六月综合| 日韩不卡免费视频| 人人精品人人爱| 精品一区二区三区免费| 国产一区视频在线看| 国产精选一区二区三区| 国产aⅴ综合色| 99在线精品一区二区三区| av中文一区二区三区| 日本久久一区二区| 在线观看www91| 欧美美女网站色| 日韩美女视频在线| 国产欧美日韩精品a在线观看| 中文字幕乱码日本亚洲一区二区| 中文字幕欧美三区| 一区二区三区不卡在线观看| 亚洲国产一二三| 美女精品一区二区| 国产九色sp调教91| 99国产欧美另类久久久精品| 欧美中文字幕不卡| 日韩精品一区二区三区老鸭窝 | 精久久久久久久久久久| 国产麻豆精品在线观看| 成人av综合在线| 欧美色手机在线观看| 欧美大片拔萝卜| 一色桃子久久精品亚洲| 性做久久久久久免费观看欧美| 精品亚洲欧美一区| 91亚洲永久精品| 欧美一区二区福利视频| 中文字幕在线免费不卡| 偷拍一区二区三区四区| 国产精品123| 7777精品伊人久久久大香线蕉最新版| 在线成人av网站| 国产精品天天看| 水蜜桃久久夜色精品一区的特点 | 91精品国产色综合久久ai换脸| 日韩欧美激情一区| 综合久久综合久久| 蜜桃av噜噜一区| 91啪九色porn原创视频在线观看| 欧美久久一二区| 亚洲少妇最新在线视频| 精品一区二区三区日韩| 在线观看视频一区| 国产精品久久午夜| 国产综合色视频| 51精品国自产在线| 亚洲免费三区一区二区| 国产精品一品视频|