人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

MySQL如何插入Emoji表情

發(fā)布日期:2022-02-23 08:46 | 文章來源:gibhub


今天在設(shè)計開源項目的反饋信息表時遇到了emoji表情插入失敗的問題,網(wǎng)上找了很多解決方案,答案五花八門,沒找到好使的。

經(jīng)過一番折騰后,終于成功插入了emoji表情,本文就跟大家分享下我的實現(xiàn)過程,歡迎各位感興趣的開發(fā)者閱讀本文。

寫在前面

我的服務(wù)器是Mac系統(tǒng),mysql使用brew安裝的,windows/linux它的配置文件位置可能有些不一樣,具體根據(jù)真實情況而定。

先跟大家看下它的報錯信息:

chat_system> UPDATE chat_system.feedback t SET t.comments = '反饋信息測試😂' WHERE t.id = 1
[2020-12-01 21:36:08] [HY000][1366] Incorrect string value: '\xF0\x9F\x98\x82' for column 'comments' at row 1
[2020-12-01 21:36:08] [HY000][1366] Incorrect string value: '\xF0\x9F\x98\x82' for column 'comments' at row 1

實現(xiàn)思路

因為數(shù)據(jù)庫默認(rèn)是UTF-8編碼格式,普通的字符串占位3個字節(jié)而表情占位4字節(jié),此時UTF-8就不夠用了,需要采用utf8mb4字符集就能解決這個問題了。

注意:utf8mb4字符集要求數(shù)據(jù)庫版本高于5.5.3。

那么,我們要做的事情如下所示:

  • 修改mysql配置文件,設(shè)置其編碼格式
  • 修改數(shù)據(jù)庫字符集編碼
  • 修改數(shù)據(jù)庫表字符集編碼

實現(xiàn)過程

mysql默認(rèn)讀取配置的順序為:/etc/my.cnf、/etc/mysql/my.cnf、/usr/local/etc/my.cnf、~/.my.cnf,如果對應(yīng)目錄下不存在這些配置文件,則需要自己新建一個。

  • 修改數(shù)據(jù)庫配置文件my.cnf,我的文件位置在: /usr/local/etc下,添加下述代碼
[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect = 'SET NAMES utf8mb4'
character-set-client-handshake = false
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
  • 修改數(shù)據(jù)庫字符集編碼,登錄mysql后執(zhí)行下述sql語句。
# 設(shè)置數(shù)據(jù)庫字符集編碼,chat_system為數(shù)據(jù)庫名稱,根據(jù)自己的實際情況而來
ALTER DATABASE chat_system CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  • 修改數(shù)據(jù)庫表的字符集編碼,登錄mysql后執(zhí)行下述sql語句。
# 設(shè)置數(shù)據(jù)庫表字符集編碼,chat_system.feedback_comment_reply為我的數(shù)據(jù)庫下對應(yīng)的表名稱,根據(jù)自己的實際情況而來
ALTER TABLE chat_system.feedback_comment_reply CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

完成上述操作后,我們來看看是否修改成功,登錄mysql后執(zhí)行下述sql語句。

SHOW VARIABLES WHERE Variable_name LIKE 'character%' OR Variable_name LIKE 'collation%';

顯示下屬信息,則表示我們已經(jīng)修改完成了。

測試用例

我們來往插入一個emoji表情來測試下:

UPDATE chat_system.feedback t SET t.comments = '反饋信息測試😂' WHERE t.id = 1;

如下所示,沒有報錯,插入成功。

我們用dataGrap查看下數(shù)據(jù)庫表中的數(shù)據(jù),如下所示,它顯示了一個?,應(yīng)該是軟件無法識別。

講道理,應(yīng)該是插入成功了,我們用postman請求接口試下,成功顯示出來了😄。

以上就是MySQL如何插入Emoji表情的詳細(xì)內(nèi)容,更多關(guān)于MySQL 插入Emoji表情的資料請關(guān)注本站其它相關(guān)文章!

海外穩(wěn)定服務(wù)器

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部