springboot與數據庫返回數據中文亂碼
問題描述:使用springboot操作數據庫時,返回的中文數據一直是亂碼
剛開始以為是springboot的問題,一直在網上搜索springboot返回數據是亂碼
結果我的問題壓根對不上邊,怎么都解決不好
后面發(fā)現應該是mysql數據庫的問題,于是上網搜索,最后判斷是字符集的問題
解決流程:
先使用sql語句查看數據庫的字符集
show variables like 'character%';

發(fā)現多處地方都不是utf8,想要修改的話要對mysql配置文件修改,網上很多修改都是使用命令修改,但是這種方法只是局部的,mysql服務重啟之后,這些修改都無效了,所以要對配置文件進行修改。
因為我的操作系統是windows,所以我的mysql配置文件是my.ini,具體路徑是在 C:\ProgramData\MySQL\MySQL Server 8.0下

可能有的電腦的ProgramData文件夾被隱藏了,只需將查看里面的隱藏的項目勾選上就行


這邊推薦先用管理員運行一個記事本,然后在里面打開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'
修改成功后使用管理員運行cmd,運行如下兩條命令,重啟mysql服務,(mysql80是服務名,也可能是叫做mysql)
net stop mysql80
net start mysql80
重啟之后再次使用mysql命令查詢字符集,發(fā)現多個字符集已經變成了utf8mb4

這時候就表示修改成功,然后此時因為修改字符集不對已存在的數據庫有效,所以你得將你所操作的數據庫刪掉,重新建,最后終于成功了!
到此這篇關于springboot與數據庫返回數據中文亂碼的文章就介紹到這了,更多相關springboot數據庫中文亂碼內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java調度線程池ScheduledThreadPoolExecutor不執(zhí)行問題分析
最近項目上反饋某個重要的定時任務突然不執(zhí)行了,很頭疼,開發(fā)環(huán)境和測試環(huán)境都沒有出現過這個問題。定時任務采用的是ScheduledThreadPoolExecutor,后來一看代碼發(fā)現踩了一個大坑。本文就來和大家聊聊這次的踩坑記錄與解決方法,需要的可以參考一下2023-03-03

