Laravel支持emoji表情存儲(chǔ)MySQL數(shù)據(jù)庫(kù)

由于需要實(shí)現(xiàn)emoji表情評(píng)論的功能搂橙,所以數(shù)據(jù)庫(kù)需要支持emoji表情的存儲(chǔ)实夹,根據(jù)查詢的資料最終實(shí)現(xiàn)了該功能,現(xiàn)將實(shí)現(xiàn)的過程以及過程遇到的一些問題記錄下來(lái)访递,供大家參考和交流晦嵌。

mysql的utf8編碼的一個(gè)字符最多3個(gè)字節(jié),但是一個(gè)emoji表情為4個(gè)字節(jié),所以u(píng)tf8不支持存儲(chǔ)emoji表情惭载。但是utf8的超集utf8mb4一個(gè)字符最多能有4字節(jié)旱函,所以能支持emoji表情的存儲(chǔ)。下面介紹了關(guān)于如何修改mysql數(shù)據(jù)庫(kù)的編碼格式變?yōu)閡tf8mb4的具體方法描滔。

Linux系統(tǒng)中MySQL的配置文件為my.cnf棒妨。(注:有空把mysql默認(rèn)編碼改為utf8的實(shí)現(xiàn)過程也記錄下來(lái))

Winows中的配置文件為my.ini。

1.修改mysql的配置文件

找到/etc/mysql路徑下的my.cnf文件含长,通過vi命令打開該文件并進(jìn)行編輯券腔,需添加如下所示配置:

[client]

default-character-set=utf8mb4

[mysqld]

character-set-client-handshake = FALSE

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

init_connect=’SET NAMES utf8mb4'

[mysql]

default-character-set=utf8mb4

修改完畢之后,通過wq保存退出

2.修改database/table和column的字符集

進(jìn)入mysql中拘泞,按下述所示進(jìn)行命令的執(zhí)行:

1) 修改database的字符集:

ALTER DATABASE 數(shù)據(jù)庫(kù)名 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

示例:

ALTER DATABASE xxxdb CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

2) 步驟1)執(zhí)行完成之后纷纫,需要執(zhí)行use 數(shù)據(jù)庫(kù)名,指明當(dāng)前需要進(jìn)行字符集修改的數(shù)據(jù)庫(kù)陪腌;示例:use xxxdb;

3)修改table的字符集:

ALTER TABLE 表名 CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

示例:

ALTER TABLE user_comments CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

4) 修改column的字符集:

ALTER TABLE 表名 CHANGE 字段名 字段名 該字段原來(lái)的數(shù)據(jù)類型 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

示例:

ALTER TABLE user_comments CHANGE content content TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

上述修改完畢辱魁,exit退出mysql

3.重啟mysql

這里重啟的時(shí)候我一開始用的是service mysql restart,最后發(fā)現(xiàn)這條命令并不管用,重啟沒有成功诗鸭,導(dǎo)致后面查看字符集的時(shí)候染簇,并沒有達(dá)到想要的字符集的狀態(tài)。

所以采用下面的方法才可以正確的重啟mysql.

3.1停止msql的運(yùn)行

通過/etc/init.d/mysql執(zhí)行stop命令

3.2啟動(dòng)mysql

通過/etc/init.d/mysql執(zhí)行start命令

4.檢查字符集:

進(jìn)入mysql中强岸,用SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';命令查看字符集的情況

上述步驟實(shí)現(xiàn)之后便可成功使用emoji表情存儲(chǔ)進(jìn)mysql數(shù)據(jù)庫(kù)的功能了锻弓。

————————————————————————————————————————————————————————————————

由于mysql數(shù)據(jù)庫(kù)是需要備份和還原的,所以帶有emoji表情的.sql文件的導(dǎo)入和導(dǎo)出的時(shí)候需要注意執(zhí)行時(shí)的編碼格式蝌箍,以下為導(dǎo)入與導(dǎo)出的具體操作:

5.帶有emoji表情的sql文件的導(dǎo)入與導(dǎo)出(主要為windows中的導(dǎo)出)

(若是在服務(wù)端的代碼中的導(dǎo)出為:mysqldump –default-character-set-utf8mb4 –u 用戶名 –p 數(shù)據(jù)庫(kù)名 > 導(dǎo)出該文件的物理路徑青灼;導(dǎo)入的命令不需要指明編碼格式,只需要正常的執(zhí)行命令便可)

5.1導(dǎo)出

在進(jìn)行把后綴名為.sql的文件十绑,且文件數(shù)據(jù)中包含emoji表情的數(shù)據(jù)聚至,進(jìn)行備份導(dǎo)出的時(shí)候酷勺,此時(shí)不要使用第三方軟件進(jìn)行導(dǎo)出本橙,而是使用命令行的形式執(zhí)行該導(dǎo)出動(dòng)作,其主要原因是使用第三方導(dǎo)出該文件時(shí)脆诉,由于其默認(rèn)的導(dǎo)出的編碼格式為utf-8,該編碼格式最多只支持3個(gè)字節(jié)甚亭,而一個(gè)emoji表情有4個(gè)字節(jié),這將導(dǎo)致emoji表情的數(shù)據(jù)變成亂碼击胜。所以在本地導(dǎo)出的時(shí)候具體操作步驟如下:

一亏狰、 打開cmd,先找到mysqldump這個(gè)執(zhí)行文件所在的路徑偶摔;

二暇唾、 在路徑后輸入mysqldump –default-character-set-utf8mb4 –u 用戶名 –p 數(shù)據(jù)庫(kù)名 > 導(dǎo)出該文件的物理路徑,按“Enter”,即可完成導(dǎo)出功能策州,在導(dǎo)出的物理路徑中即可找到已被導(dǎo)出的該文件瘸味。

5.2導(dǎo)入

把linux系統(tǒng)中的.sql文件導(dǎo)入到本地的時(shí)候,不要使用Navicat Premium來(lái)進(jìn)行導(dǎo)入够挂,而是使用如下所示的命令行中的source .sql文件的物理路徑旁仿,來(lái)進(jìn)行如下的導(dǎo)入。

6.1使用的laravel框架如果出現(xiàn)表情插入數(shù)據(jù)庫(kù)中為問號(hào)

需要修改

在laravel的數(shù)據(jù)庫(kù)配置文件`config/databases.php`中設(shè)置mysql連接的編碼

'mysql' => [

'driver' => 'mysql',

'host' => env('DB_HOST', 'localhost'),

'port' => env('DB_PORT', '3306'),

'database' => env('DB_DATABASE', 'forge'),

'username' => env('DB_USERNAME', 'forge'),

'password' => env('DB_PASSWORD', ''),

'charset' => 'utf8mb4',? //重點(diǎn)

'collation' => 'utf8mb4_unicode_ci',? //重點(diǎn)

'prefix' => 'FN_',

'strict' => false,

'engine' => null,

],

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末孽糖,一起剝皮案震驚了整個(gè)濱河市枯冈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌办悟,老刑警劉巖尘奏,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異誉尖,居然都是意外死亡罪既,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門铡恕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)琢感,“玉大人,你說(shuō)我怎么就攤上這事探熔【哉耄” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵诀艰,是天一觀的道長(zhǎng)柬甥。 經(jīng)常有香客問我,道長(zhǎng)其垄,這世上最難降的妖魔是什么苛蒲? 我笑而不...
    開封第一講書人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮绿满,結(jié)果婚禮上臂外,老公的妹妹穿的比我還像新娘。我一直安慰自己喇颁,他們只是感情好漏健,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著橘霎,像睡著了一般蔫浆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上姐叁,一...
    開封第一講書人閱讀 51,182評(píng)論 1 299
  • 那天瓦盛,我揣著相機(jī)與錄音洗显,去河邊找鬼。 笑死原环,一個(gè)胖子當(dāng)著我的面吹牛墙懂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播扮念,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼损搬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了柜与?” 一聲冷哼從身側(cè)響起巧勤,我...
    開封第一講書人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎弄匕,沒想到半個(gè)月后颅悉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡迁匠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年剩瓶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片城丧。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡延曙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出亡哄,到底是詐尸還是另有隱情枝缔,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布蚊惯,位于F島的核電站愿卸,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏截型。R本人自食惡果不足惜趴荸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宦焦。 院中可真熱鬧发钝,春花似錦、人聲如沸赶诊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)舔痪。三九已至,卻和暖如春锌唾,著一層夾襖步出監(jiān)牢的瞬間锄码,已是汗流浹背夺英。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留滋捶,地道東北人痛悯。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像重窟,于是被迫代替她去往敵國(guó)和親载萌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • https://my.oschina.net/wingyiu/blog/153357 MYSQL 5.5 之前巡扇, ...
    愛蛇閱讀 2,730評(píng)論 0 0
  • 轉(zhuǎn) 問題描述: 如果UTF8字符集且是Java服務(wù)器的話扭仁,當(dāng)存儲(chǔ)含有emoji表情時(shí),會(huì)拋出類似如下異常: jav...
    天上掉陷阱閱讀 760評(píng)論 0 3
  • 一厅翔、完成時(shí)間及成果: (一)乖坠、9月10日定的周目標(biāo),從9月11日至9月17日刀闷,最初預(yù)計(jì)時(shí)間是54.5小時(shí)熊泵,三天應(yīng)該...
    小奇之旅閱讀 116評(píng)論 0 0
  • nomoreoo閱讀 394評(píng)論 0 0
  • 夢(mèng)隨風(fēng)萬(wàn)里,雪融似淚珠甸昏。 念千古風(fēng)情顽分,又到春碧雨。 ...
    千樽羽心閱讀 806評(píng)論 2 2