您好,登錄后才能下訂單哦!
小編給大家分享一下springboot與數(shù)據(jù)庫返回?cái)?shù)據(jù)中文亂碼怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
問題描述:使用springboot操作數(shù)據(jù)庫時(shí),返回的中文數(shù)據(jù)一直是亂碼
剛開始以為是springboot的問題,一直在網(wǎng)上搜索springboot返回?cái)?shù)據(jù)是亂碼
結(jié)果我的問題壓根對不上邊,怎么都解決不好
后面發(fā)現(xiàn)應(yīng)該是mysql數(shù)據(jù)庫的問題,于是上網(wǎng)搜索,最后判斷是字符集的問題
解決流程:
先使用sql語句查看數(shù)據(jù)庫的字符集
show variables like 'character%';
發(fā)現(xiàn)多處地方都不是utf8,想要修改的話要對mysql配置文件修改,網(wǎng)上很多修改都是使用命令修改,但是這種方法只是局部的,mysql服務(wù)重啟之后,這些修改都無效了,所以要對配置文件進(jìn)行修改。
因?yàn)槲业牟僮飨到y(tǒng)是windows,所以我的mysql配置文件是my.ini,具體路徑是在 C:\ProgramData\MySQL\MySQL Server 8.0下
可能有的電腦的ProgramData文件夾被隱藏了,只需將查看里面的隱藏的項(xiàng)目勾選上就行
這邊推薦先用管理員運(yùn)行一個(gè)記事本,然后在里面打開my.ini文件
分別找到[client][mysql][mysqld]下面添加上如下代碼塊,注意前面不要加#
[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 COLLATE utf8mb4_unicode_ci' init_connect = 'SET collation_connection = utf8mb4_unicode_ci'
修改成功后使用管理員運(yùn)行cmd,運(yùn)行如下兩條命令,重啟mysql服務(wù),(mysql80是服務(wù)名,也可能是叫做mysql)
net stop mysql80
net start mysql80
重啟之后再次使用mysql命令查詢字符集,發(fā)現(xiàn)多個(gè)字符集已經(jīng)變成了utf8mb4
這時(shí)候就表示修改成功,然后此時(shí)因?yàn)樾薷淖址粚σ汛嬖诘臄?shù)據(jù)庫有效,所以你得將你所操作的數(shù)據(jù)庫刪掉,重新建,最后終于成功了!
以上是“springboot與數(shù)據(jù)庫返回?cái)?shù)據(jù)中文亂碼怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。