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

主頁 > 知識庫 > 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】的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    91麻豆精品国产91久久久更新时间| 国产不卡在线播放| 亚洲精品一二三四区| 亚洲大型综合色站| 青青草97国产精品免费观看| 国产在线精品视频| 色婷婷综合激情| 成人性生交大片免费看在线播放| 国产久卡久卡久卡久卡视频精品| 成人在线视频一区二区| 色婷婷av一区二区三区软件 | 久久99精品久久久久久| 国产一区二区三区综合| 色婷婷久久99综合精品jk白丝 | 久久精品二区亚洲w码| 福利电影一区二区| 精品福利在线导航| 一区二区三区四区在线免费观看| 肉丝袜脚交视频一区二区| 91在线码无精品| 精品久久一区二区三区| 亚洲综合久久久久| 色94色欧美sute亚洲线路二| 日韩小视频在线观看专区| 亚洲欧美一区二区三区极速播放 | 成人精品小蝌蚪| 日韩色视频在线观看| 一区二区三区在线影院| 精品一区二区在线视频| 欧美色综合久久| 国产精品三级在线观看| 男男gaygay亚洲| 91丝袜美腿高跟国产极品老师 | 久久看人人爽人人| 丝袜国产日韩另类美女| 91网站在线播放| 人人狠狠综合久久亚洲| 国产三级久久久| 日韩三级精品电影久久久| 日韩高清不卡一区二区三区| 久久毛片高清国产| 国产乱对白刺激视频不卡| 亚洲人成网站色在线观看| 欧美一区在线视频| 欧美日韩一级视频| 国v精品久久久网| 国产综合久久久久影院| 欧美日韩国产欧美日美国产精品| 国产精品麻豆欧美日韩ww| 在线精品视频小说1| 国产成人精品影视| 懂色av一区二区三区免费观看 | 欧美日韩成人高清| 成人免费在线观看入口| 91免费版在线| 日韩在线一区二区| 亚洲欧美自拍偷拍| 国产欧美一区二区精品忘忧草| 99精品热视频| 99久久99久久精品免费观看 | 国产中文一区二区三区| 亚洲综合免费观看高清完整版在线| 欧美在线观看一二区| 粉嫩在线一区二区三区视频| www国产亚洲精品久久麻豆| 精品一二三四区| 久久99精品久久久久婷婷| 久久国产精品99精品国产| 色嗨嗨av一区二区三区| 91污在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 福利91精品一区二区三区| 久久99久久99小草精品免视看| 久久av老司机精品网站导航| 国内久久婷婷综合| 99精品在线免费| 欧美另类高清zo欧美| 久久精子c满五个校花| 欧美高清www午色夜在线视频| 另类小说色综合网站| 成人毛片在线观看| 欧美性videosxxxxx| 国产欧美日韩中文久久| 日韩av网站在线观看| 日韩精品国产欧美| 亚洲女人****多毛耸耸8| 日韩网站在线看片你懂的| 94-欧美-setu| 777奇米四色成人影色区| 欧美一区二区人人喊爽| 中文字幕一区二区5566日韩| 亚洲香蕉伊在人在线观| 青青草97国产精品免费观看无弹窗版| 99精品久久只有精品| 日韩视频在线永久播放| 亚洲天堂成人在线观看| 亚洲影视在线播放| 琪琪久久久久日韩精品| 欧美精品欧美精品系列| 欧美日韩另类国产亚洲欧美一级| 亚洲男人电影天堂| 久久嫩草精品久久久久| 欧美视频在线观看一区| 国产一区二区三区国产| 亚洲福利视频一区二区| 国产日韩视频一区二区三区| 欧美日韩和欧美的一区二区| 懂色一区二区三区免费观看| 午夜精品福利视频网站 | 国产一二三精品| 日韩经典一区二区| 五月激情综合网| 亚洲国产成人精品视频| 亚洲午夜在线观看视频在线| 亚洲国产精华液网站w| 国产日韩欧美电影| 久久久国产午夜精品| 久久一区二区三区四区| 久久众筹精品私拍模特| 久久久久久99精品| 亚洲国产成人私人影院tom| 国产欧美日韩精品一区| 国产人成亚洲第一网站在线播放| 日韩女优视频免费观看| 精东粉嫩av免费一区二区三区| 午夜电影网亚洲视频| 亚洲图片一区二区| 蜜桃一区二区三区四区| 亚洲欧美一区二区三区国产精品 | 欧美性xxxxx极品少妇| 国产一区二区三区av电影| 琪琪久久久久日韩精品| 激情国产一区二区| 天天综合色天天综合| 婷婷综合久久一区二区三区| 亚洲高清免费观看| 成人精品国产一区二区4080| 成人午夜电影久久影院| 91美女蜜桃在线| 欧美视频一区二区三区| 7777精品伊人久久久大香线蕉| 91精品国产综合久久精品麻豆| 欧美大片一区二区| 国产精品天干天干在观线| 亚洲码国产岛国毛片在线| 日韩激情视频在线观看| 国产一区二区电影| 日本精品裸体写真集在线观看| 欧美性猛交xxxx乱大交退制版| 日韩一区二区电影网| 国产精品卡一卡二卡三| 亚洲成年人影院| 国产成人在线电影| 欧美日韩夫妻久久| 国产精品理论在线观看| 视频一区视频二区在线观看| 国产高清成人在线| 欧美日韩国产精品成人| 国产亚洲欧美在线| 亚洲成人精品在线观看| 成人性视频免费网站| 91精品国产一区二区三区蜜臀 | 五月天激情综合| 成人免费毛片片v| 51精品秘密在线观看| 中文字幕一区二区三区四区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产精品久久久久久亚洲毛片 | 日韩精品久久久久久| 成人av在线资源网站| 精品国产一二三| 一区二区欧美视频| 成人一二三区视频| 2024国产精品| 免费的国产精品| 欧美吞精做爰啪啪高潮| 国产精品不卡在线观看| 国产一区二区三区四区在线观看| 欧美三区免费完整视频在线观看| 国产女同互慰高潮91漫画| 精东粉嫩av免费一区二区三区| 欧美性生活影院| 国产情人综合久久777777| 精品一区二区三区的国产在线播放 | 成人97人人超碰人人99| 久久蜜桃香蕉精品一区二区三区| 天天综合日日夜夜精品| 欧美日韩精品电影| 夜夜嗨av一区二区三区| 91免费观看视频| 亚洲精品中文在线| 色综合久久久网| 国产精品素人视频| 成人性视频网站| 国产精品久久久久久亚洲毛片| 福利视频网站一区二区三区| 久久日一线二线三线suv| 免费一级片91| 日韩欧美国产一区在线观看| 天天综合色天天|