MySQL字符集utf8修改為utf8mb4的方法步驟
對(duì)于mysql 5.5 而言,如果不設(shè)定字符集,mysql默認(rèn)的字符集是 latin1 拉丁文字符集;
但隨著各種業(yè)務(wù)的進(jìn)一步發(fā)展,除了各個(gè)國(guó)家的本身語(yǔ)言字符,經(jīng)常也會(huì)有一些表情符號(hào)出現(xiàn)在應(yīng)用程序中,而在mysql 5.5 之前,UTF-8編碼只支持1-3個(gè)字節(jié),支持BMP這部分的Unicode編碼區(qū);從MySQL 5.5開(kāi)始,可以支持4個(gè)字節(jié)UTF編碼 utf8mb4 ,一個(gè)字符能夠支持更多的字符集,也能夠支持更多表情符號(hào)。
utf8mb4兼容utf8,且比utf8能表示更多的字符,是utf8字符集的超集。所以現(xiàn)在一些新的業(yè)務(wù),比如ISO等,會(huì)將MySQL數(shù)據(jù)庫(kù)的字符集設(shè)置為utf8mb4。
今天在處理一個(gè)應(yīng)用需求的時(shí)候,就遇到這樣一個(gè)問(wèn)題:
當(dāng)然調(diào)整的最好方法是客戶端,mysql數(shù)據(jù)庫(kù)的字符集都修改為utf8mb4,但這樣修改量比較大,而且如果客戶端一部分修改為utf8,一部分為utf8mb4的話,容易發(fā)生混亂。
經(jīng)過(guò)幾次測(cè)試后,MySQL數(shù)據(jù)庫(kù)的my.cnf中關(guān)于字符集的配置修改為下面的配置了:
[client] default-character-set=utf8mb4 [mysqld] character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci init_connect='SET NAMES utf8mb4' skip-character-set-client-handshake = true [mysql] default-character-set = utf8mb4
使用MySQL字符集時(shí)的建議
• 建立數(shù)據(jù)庫(kù)/表和進(jìn)行數(shù)據(jù)庫(kù)操作時(shí)盡量顯式指出使用的字符集,而不是依賴于MySQL的默認(rèn)設(shè)置,否則MySQL升級(jí)時(shí)可能帶來(lái)很大困擾;
• 數(shù)據(jù)庫(kù)和連接字符集都使用latin1時(shí)雖然大部分情況下都可以解決亂碼問(wèn)題,但缺點(diǎn)是無(wú)法以字符為單位來(lái)進(jìn)行SQL操作,一般情況下將數(shù)據(jù)庫(kù)和連接字符集都置為utf8是較好的選擇;
• 使用mysql C API時(shí),初始化數(shù)據(jù)庫(kù)句柄后馬上用mysql_options設(shè)定MYSQL_SET_CHARSET_NAME屬性為utf8,這樣就不用顯式地用 SET NAMES語(yǔ)句指定連接字符集,且用mysql_ping重連斷開(kāi)的長(zhǎng)連接時(shí)也會(huì)把連接字符集重置為utf8;
• 對(duì)于mysql PHP API,一般頁(yè)面級(jí)的PHP程序總運(yùn)行時(shí)間較短,在連接到數(shù)據(jù)庫(kù)以后顯式用SET NAMES語(yǔ)句設(shè)置一次連接字符集即可;但當(dāng)使用長(zhǎng)連接時(shí),請(qǐng)注意保持連接通暢并在斷開(kāi)重連后用SET NAMES語(yǔ)句顯式重置連接字符集。
全面了解mysql中utf8和utf8mb4的區(qū)別:http://chabaoo.cn/article/90037.htm
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
MySQL數(shù)據(jù)庫(kù)十大優(yōu)化技巧
WEB開(kāi)發(fā)者不光要解決程序的效率問(wèn)題,對(duì)數(shù)據(jù)庫(kù)的快速訪問(wèn)和相應(yīng)也是一個(gè)大問(wèn)題。希望本文能對(duì)大家掌握MySQL優(yōu)化技巧有所幫助。2011-03-03MySQL中修改表結(jié)構(gòu)時(shí)需要注意的一些地方
這篇文章主要介紹了MySQL中修改表結(jié)構(gòu)時(shí)需要注意的一些地方,作者援引Percona的相關(guān)的說(shuō)明來(lái)講述如何避免相關(guān)操作導(dǎo)致表無(wú)法使用的問(wèn)題,一些需要的朋友可以參考下2015-06-06Mysql 5.7.18安裝方法及啟動(dòng)MySQL服務(wù)的過(guò)程詳解
這篇文章主要介紹了Mysql 5.7.18安裝方法及啟動(dòng)MySQL服務(wù)的過(guò)程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05詳解MySQL存儲(chǔ)過(guò)程的創(chuàng)建和調(diào)用
這篇文章主要為大家介紹了MySQL存儲(chǔ)過(guò)程的創(chuàng)建和調(diào)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12mysql 數(shù)據(jù)庫(kù)備份和還原方法集錦 推薦
本文討論 MySQL 的備份和恢復(fù)機(jī)制,以及如何維護(hù)數(shù)據(jù)表,包括最主要的兩種表類型:MyISAM 和 Innodb,文中設(shè)計(jì)的 MySQL 版本為 5.0.22。2010-03-03解決啟動(dòng)MySQL服務(wù)時(shí)出現(xiàn)"mysql本地計(jì)算機(jī)上的MySQL服務(wù)啟動(dòng)后停止"的問(wèn)題
某一天我的MySQL啟動(dòng)突然出現(xiàn)了異常:“mysql本地計(jì)算機(jī)上的MySQL服務(wù)啟動(dòng)后停止,某些在未由其他服務(wù)或程序使用時(shí)將自動(dòng)停止,”?,小編在網(wǎng)絡(luò)上面找了很多方法,MySQL啟動(dòng)成功了,但是第二天開(kāi)啟MySQL時(shí)還是出現(xiàn)了這個(gè)問(wèn)題,現(xiàn)把兩種方法總結(jié)一下,需要的朋友可以參考下2023-11-11