主頁 > 知識(shí)庫 > 設(shè)置mysql5.7編碼集為utf8mb4的方法

設(shè)置mysql5.7編碼集為utf8mb4的方法

熱門標(biāo)簽:400電話辦理都選易號網(wǎng) 如何在高德地圖標(biāo)注新地址 高德地圖標(biāo)注中心個(gè)人注冊 外呼系統(tǒng)防封號違法嗎 電銷機(jī)器人針對的 外呼系統(tǒng)服務(wù) 湘潭電銷機(jī)器人咨詢電話 寶應(yīng)電信400電話辦理費(fèi)用 高德地圖標(biāo)注模式

最近遇到一個(gè)問題,移動(dòng)端的表情或者一些emoji是4字節(jié)的,但是utf-8是3字節(jié)的,查了很多網(wǎng)上的解決方法,最后提供一套自己的解決方案。如果當(dāng)前的困境是:自己的mysql版本為5.5.3以前(版本為5.5.3以前將不能使用utf-8mb4編碼),需要重裝更高版本的mysql,然后獲得該編碼。

1,檢查自己當(dāng)前數(shù)據(jù)庫版本

使用命令: select version();

如果發(fā)現(xiàn)當(dāng)前的數(shù)據(jù)庫版本在5.5.3以前,則需要重裝數(shù)據(jù)庫,如果在該版本之后跳過第二步和第三步。

2,備份當(dāng)前數(shù)據(jù)庫中的數(shù)據(jù)

這里我使用的數(shù)據(jù)庫可視化軟件是navicat,在數(shù)據(jù)庫下右鍵對應(yīng)的數(shù)據(jù)庫,然后選擇“轉(zhuǎn)儲(chǔ)SQL文件”選擇“數(shù)據(jù)和結(jié)構(gòu)”導(dǎo)出后綴為.sql 的數(shù)據(jù)庫文件保存硬盤里,當(dāng)安裝好新的數(shù)據(jù)庫版本后,再選定數(shù)據(jù)庫,右鍵“運(yùn)行SQL文件”這樣數(shù)據(jù)就不會(huì)丟失

3,徹底刪除當(dāng)前數(shù)據(jù)庫

數(shù)據(jù)庫的刪除很繁瑣,有時(shí)候刪不干凈,我這里參考了一些方法,親測可用。

3.1 刪除Mysql的服務(wù)

控制面板——》所有控制面板項(xiàng)——》程序和功能,卸載mysql server!

3.2 刪除mysql目錄下所有文件

刪除mysql文件夾下的my.ini文件及所有文件
一般的安裝目錄在:C:\Program Files\MySQL

3.3 刪除注冊表信息

同時(shí)按下“win”+ R 然后輸入regedit進(jìn)入注冊表管理器

刪除:

HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL文件夾

刪除:

HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL文件夾。

刪除:

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL的文件夾 

如果沒有或者不存在以上文件夾就不用管了

3.4 刪除隱藏的mysql文件夾

一般以隱藏的形式存在,在C盤下搜索該目錄應(yīng)該可以查到C:\ProgramData\MySQL\MySQL Server 5.7

4 安裝數(shù)據(jù)庫mysql5.7

首先下載mysql5.7,我使用的是msi版本,安裝過程就不詳細(xì)敘述了,總之最后安裝到默認(rèn)路徑也就是C盤下了,安裝好之后,為了調(diào)出小黑窗,我配置了系統(tǒng)環(huán)境變量

 

 

在系統(tǒng)變量那一塊兒選擇path,在path下輸入數(shù)據(jù)庫的安裝路徑就可以了,具體到bin文件夾的路徑就好,這時(shí)調(diào)出小黑窗查看自己的編碼格式

語句是: SHOW VARIABLES LIKE ‘character_set%';

顯示的應(yīng)該都是utf-8,因?yàn)榘惭b默認(rèn)就是utf-8

5 修改編碼格式

首先要在配置文件里(my.ini)下修改配置,但是我們發(fā)現(xiàn)安裝目錄里并沒有該文件

 

這個(gè)就是令我一下午懊惱的地方,后來通過查閱資料,發(fā)現(xiàn)該文件隱藏在c盤里的隱藏文件夾,還是在c盤下搜索 C:\ProgramData\MySQL\MySQL Server 5.7

找到了該文件:

在該my.ini文件下進(jìn)行配置修改

[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'

注意,以上加粗的兩條在原文件配置中有,值都為utf-8,所以加入這兩條的時(shí)候一定要替換掉原來的,否則mysql無法讀取配置文件,服務(wù)無法啟動(dòng)。

修改完成后保存,然后重啟數(shù)據(jù)庫的服務(wù),重啟服務(wù)的地址如下

 

然后在小黑窗里再敲兩條字符集命令驗(yàn)證一下

SHOW VARIABLES LIKE ‘character_set%'; 

數(shù)據(jù)庫的字符集已經(jīng)被修改過來了

 

SHOW VARIABLES LIKE ‘collation%'; 

數(shù)據(jù)表的字符集也都被修改了

值得注意的是,utf8mb4兼容utf-8,所以不用擔(dān)心原來的數(shù)據(jù)出現(xiàn)亂碼情況

如果你使用的是版本5.5.3之前的mysql為了不亂碼而且也不想修改編碼集,那么你可以用MEDIUMBLOB的形式存儲(chǔ)數(shù)據(jù),但我不是很推薦

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 如何更改MySQL數(shù)據(jù)庫的編碼為utf8mb4
  • Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
  • mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
  • MySQL 編碼utf8 與 utf8mb4 utf8mb4_unicode_ci 與 utf8mb4_general_ci

標(biāo)簽:黔南 黃山 賀州 宿遷 佛山 蘭州 馬鞍山 南充

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《設(shè)置mysql5.7編碼集為utf8mb4的方法》,本文關(guān)鍵詞  設(shè)置,mysql5.7,編碼,集,為,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《設(shè)置mysql5.7編碼集為utf8mb4的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于設(shè)置mysql5.7編碼集為utf8mb4的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章