設(shè)置mysql5.7編碼集為utf8mb4的方法
最近遇到一個(gè)問(wèn)題,移動(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ù)庫(kù)版本
使用命令: select version();
如果發(fā)現(xiàn)當(dāng)前的數(shù)據(jù)庫(kù)版本在5.5.3以前,則需要重裝數(shù)據(jù)庫(kù),如果在該版本之后跳過(guò)第二步和第三步。
2,備份當(dāng)前數(shù)據(jù)庫(kù)中的數(shù)據(jù)
這里我使用的數(shù)據(jù)庫(kù)可視化軟件是navicat,在數(shù)據(jù)庫(kù)下右鍵對(duì)應(yīng)的數(shù)據(jù)庫(kù),然后選擇“轉(zhuǎn)儲(chǔ)SQL文件”選擇“數(shù)據(jù)和結(jié)構(gòu)”導(dǎo)出后綴為.sql 的數(shù)據(jù)庫(kù)文件保存硬盤里,當(dāng)安裝好新的數(shù)據(jù)庫(kù)版本后,再選定數(shù)據(jù)庫(kù),右鍵“運(yùn)行SQL文件”這樣數(shù)據(jù)就不會(huì)丟失
3,徹底刪除當(dāng)前數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)的刪除很繁瑣,有時(shí)候刪不干凈,我這里參考了一些方法,親測(cè)可用。
3.1 刪除Mysql的服務(wù)
控制面板——》所有控制面板項(xiàng)——》程序和功能,卸載mysql server!
3.2 刪除mysql目錄下所有文件
刪除mysql文件夾下的my.ini文件及所有文件
一般的安裝目錄在:C:\Program Files\MySQL
3.3 刪除注冊(cè)表信息
同時(shí)按下“win”+ R 然后輸入regedit進(jìn)入注冊(cè)表管理器
刪除:
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的文件夾
如果沒(méi)有或者不存在以上文件夾就不用管了
3.4 刪除隱藏的mysql文件夾
一般以隱藏的形式存在,在C盤下搜索該目錄應(yīng)該可以查到C:\ProgramData\MySQL\MySQL Server 5.7
4 安裝數(shù)據(jù)庫(kù)mysql5.7
首先下載mysql5.7,我使用的是msi版本,安裝過(guò)程就不詳細(xì)敘述了,總之最后安裝到默認(rèn)路徑也就是C盤下了,安裝好之后,為了調(diào)出小黑窗,我配置了系統(tǒng)環(huán)境變量
在系統(tǒng)變量那一塊兒選擇path,在path下輸入數(shù)據(jù)庫(kù)的安裝路徑就可以了,具體到bin文件夾的路徑就好,這時(shí)調(diào)出小黑窗查看自己的編碼格式
語(yǔ)句是: SHOW VARIABLES LIKE ‘character_set%';
顯示的應(yīng)該都是utf-8,因?yàn)榘惭b默認(rèn)就是utf-8
5 修改編碼格式
首先要在配置文件里(my.ini)下修改配置,但是我們發(fā)現(xiàn)安裝目錄里并沒(méi)有該文件
這個(gè)就是令我一下午懊惱的地方,后來(lái)通過(guò)查閱資料,發(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í)候一定要替換掉原來(lái)的,否則mysql無(wú)法讀取配置文件,服務(wù)無(wú)法啟動(dòng)。
修改完成后保存,然后重啟數(shù)據(jù)庫(kù)的服務(wù),重啟服務(wù)的地址如下
然后在小黑窗里再敲兩條字符集命令驗(yàn)證一下
SHOW VARIABLES LIKE ‘character_set%';
數(shù)據(jù)庫(kù)的字符集已經(jīng)被修改過(guò)來(lái)了
SHOW VARIABLES LIKE ‘collation%';
數(shù)據(jù)表的字符集也都被修改了
值得注意的是,utf8mb4兼容utf-8,所以不用擔(dān)心原來(lái)的數(shù)據(jù)出現(xiàn)亂碼情況
如果你使用的是版本5.5.3之前的mysql為了不亂碼而且也不想修改編碼集,那么你可以用MEDIUMBLOB的形式存儲(chǔ)數(shù)據(jù),但我不是很推薦
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 更改MySQL數(shù)據(jù)庫(kù)的編碼為utf8mb4問(wèn)題
- MySQL 編碼utf8 與 utf8mb4 utf8mb4_unicode_ci 與 utf8mb4_general_ci
- 如何更改MySQL數(shù)據(jù)庫(kù)的編碼為utf8mb4
- MySQL字符集utf8修改為utf8mb4的方法步驟
- 詳解JDBC對(duì)Mysql utf8mb4字符集的處理
- Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
- mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
- 全面了解mysql中utf8和utf8mb4的區(qū)別
- mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別
相關(guān)文章
在CMD中操作mysql數(shù)據(jù)庫(kù)出現(xiàn)中文亂碼解決方案
有說(shuō)將cmd字符編碼用chcp命令改為65001(utf8字符編碼),可這樣之后根本無(wú)法輸入中文,查詢出的中問(wèn)結(jié)果依舊亂碼 。下面小編給大家?guī)?lái)了在CMD中操作mysql數(shù)據(jù)庫(kù)出現(xiàn)中文亂碼解決方案,一起看看吧2017-09-09十個(gè)節(jié)省時(shí)間的MySQL命令小結(jié)
編者在工作中積累起來(lái)了一些MySQL命令行客戶端技巧,這些技巧或多或少會(huì)幫助您節(jié)省大量的時(shí)間。2011-03-03mysql 無(wú)法聯(lián)接常見(jiàn)故障及原因分析
這篇文章主要介紹了mysql 無(wú)法聯(lián)接常見(jiàn)故障及原因分析,本文是小編日常收集整理的,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11LEFT JOIN關(guān)聯(lián)表中ON,WHERE后面跟條件的區(qū)別
本文主要介紹了LEFT JOIN關(guān)聯(lián)表中ON,WHERE后面跟條件的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01MySQL數(shù)據(jù)庫(kù)誤操作后快速回滾的方法
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)誤操作后快速回滾的方法的相關(guān)資料,需要的朋友可以參考下2016-12-12MySQL服務(wù)器默認(rèn)安裝之后調(diào)節(jié)性能的方法
在面試MySQL DBA或者那些打算做MySQL性能優(yōu)化的人時(shí),我最喜歡問(wèn)題是:MySQL服務(wù)器按照默認(rèn)設(shè)置安裝完之后,應(yīng)該做哪些方面的調(diào)節(jié)呢?2011-05-05Mysql數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程基本語(yǔ)法講解
本文通過(guò)一個(gè)實(shí)例來(lái)給大家講述一下Mysql數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程基本語(yǔ)法,希望你能喜歡。2017-11-11Linux下mysql 8.0.15 安裝配置圖文教程以及修改密碼
這篇文章主要為大家詳細(xì)介紹了Linux下mysql 8.0.15安裝配置圖文教程以及修改密碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03update.where無(wú)索引導(dǎo)致MySQL死鎖問(wèn)題解決
這篇文章主要為大家介紹了update.where無(wú)索引導(dǎo)致MySQL死鎖問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11