1. 程式人生 > >【解決方案 二】---設定mysql5.7編碼集為utf8mb4

【解決方案 二】---設定mysql5.7編碼集為utf8mb4

最近遇到一個問題,移動端的表情或者一些emoji是4位元組的,但是utf-8是3位元組的,查了很多網上的解決方法,最後提供一套自己的解決方案。如果當前的困境是:自己的mysql版本為5.5.3以前(版本為5.5.3以前將不能使用utf-8mb4編碼),需要重灌更高版本的mysql,然後獲得該編碼。

1,檢查自己當前資料庫版本

使用命令: select version();

這裡寫圖片描述

如果發現當前的資料庫版本在5.5.3以前,則需要重灌資料庫,如果在該版本之後跳過第二步和第三步。

2,備份當前資料庫中的資料

這裡我使用的資料庫視覺化軟體是navicat,在資料庫下右鍵對應的資料庫,然後選擇“轉儲SQL檔案”選擇“資料和結構”匯出字尾為.sql 的資料庫檔案儲存硬盤裡,當安裝好新的資料庫版本後,再選定資料庫,右鍵“執行SQL檔案”這樣資料就不會丟失

3,徹底刪除當前資料庫

資料庫的刪除很繁瑣,有時候刪不乾淨,我這裡參考了一些方法,親測可用。

3.1 刪除Mysql的服務

控制面板——》所有控制面板項——》程式和功能,解除安裝mysql server!

這裡寫圖片描述

3.2 刪除mysql目錄下所有檔案

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

3.3 刪除登錄檔資訊

同時按下“win”+ R 然後輸入regedit進入登錄檔管理器
刪除:
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盤下搜尋該目錄應該可以查到C:\ProgramData\MySQL\MySQL Server 5.7

4 安裝資料庫mysql5.7

首先下載mysql5.7,我使用的是msi版本,安裝過程就不詳細敘述了,總之最後安裝到預設路徑也就是C盤下了,安裝好之後,為了調出小黑窗,我配置了系統環境變數
這裡寫圖片描述
這裡寫圖片描述
在系統變數那一塊兒選擇path,在path下輸入資料庫的安裝路徑就可以了,具體到bin資料夾的路徑就好,這時調出小黑窗檢視自己的編碼格式
語句是: SHOW VARIABLES LIKE ‘character_set%’;
顯示的應該都是utf-8,因為安裝預設就是utf-8

5 修改編碼格式

首先要在配置檔案裡(my.ini)下修改配置,但是我們發現安裝目錄裡並沒有該檔案

這裡寫圖片描述
這個就是令我一下午懊惱的地方,後來通過查閱資料,發現該檔案隱藏在c盤裡的隱藏資料夾,還是在c盤下搜尋 C:\ProgramData\MySQL\MySQL Server 5.7
找到了該檔案:
這裡寫圖片描述

在該my.ini檔案下進行配置修改
[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,所以加入這兩條的時候一定要替換掉原來的,否則mysql無法讀取配置檔案,服務無法啟動。
修改完成後儲存,然後重啟資料庫的服務,重啟服務的地址如下
這裡寫圖片描述
然後在小黑窗裡再敲兩條字符集命令驗證一下
SHOW VARIABLES LIKE ‘character_set%’;
資料庫的字符集已經被修改過來了
這裡寫圖片描述
SHOW VARIABLES LIKE ‘collation%’;
資料表的字符集也都被修改了
這裡寫圖片描述

值得注意的是,utf8mb4相容utf-8,所以不用擔心原來的資料出現亂碼情況
如果你使用的是版本5.5.3之前的mysql為了不亂碼而且也不想修改編碼集,那麼你可以用MEDIUMBLOB的形式儲存資料,但我不是很推薦

花了2小時解決了一個問題,希望對自己之後的工作有幫助
工作日誌:該工作完成與2017-6-14 下午3點-5點,為了海量微博資料的正常顯示