Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
1 問(wèn)題:數(shù)據(jù)庫(kù)字符集和排序規(guī)則不一致
最近需要向一個(gè)已有的數(shù)據(jù)庫(kù)進(jìn)行擴(kuò)充(已有數(shù)據(jù)庫(kù)是由PHP建的,后來(lái)由Java進(jìn)行擴(kuò)展),但是出現(xiàn)了新表和舊表無(wú)法建立外鍵的問(wèn)題,后來(lái)發(fā)現(xiàn)是因?yàn)榫幋a問(wèn)題,服務(wù)器數(shù)據(jù)庫(kù)和我本地?cái)?shù)據(jù)庫(kù)的字符集和排序規(guī)則不對(duì)應(yīng),服務(wù)器數(shù)據(jù)庫(kù)使用的是utf8mb4,utf8mb4_unicode_ci而我本地使用的是utf8,utf8_general_ci。
2 解決方法
2.1 將本地?cái)?shù)據(jù)庫(kù)改成utf8mb4,utf8mb4_unicode_ci
該方法參考: 更改MySQL數(shù)據(jù)庫(kù)的編碼為utf8mb4
2.1.1 找到my.cnf,一般在/etc/mysql/my.cnf,可以用locate my.cnf查找。修改下面三部分
[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'
2.1.2 重啟數(shù)據(jù)庫(kù),檢查變量
必須保證
系統(tǒng)變量 | 描述 |
---|---|
character_set_client | (客戶(hù)端來(lái)源數(shù)據(jù)使用的字符集) |
character_set_connection | (連接層字符集) |
character_set_database | (當(dāng)前選中數(shù)據(jù)庫(kù)的默認(rèn)字符集) |
character_set_results | (查詢(xún)結(jié)果字符集) |
character_set_server | (默認(rèn)的內(nèi)部操作字符集) |
這幾個(gè)變量必須是utf8mb4。
2.1.3 將已經(jīng)建好的數(shù)據(jù)庫(kù)、表和列轉(zhuǎn)換成utf8mb4,utf8mb4_unicode_ci
更改數(shù)據(jù)庫(kù)編碼:ALTER DATABASE database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
更改表編碼:ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
更改列編碼:ALTER TABLE table_name CHANGE column_name column_name VARCHAR( 36 ) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL
Mysql官方文檔
Database Character Set and Collation
Table Character Set and Collation
Column Character Set and Collation
如果我不想修改本地?cái)?shù)據(jù)庫(kù)呢?那就用下面這種方法。(我用的是第二種)
2.2 在Spring Boot中配置,不修改本地?cái)?shù)據(jù)庫(kù)
2.2.1 在JPA建表時(shí)設(shè)置表的編碼和排序規(guī)則
重寫(xiě)MySQL5InnoDBDialect#getTableTypeString()
public class MySQL5InnoDBDialectUtf8mb4 extends MySQL5InnoDBDialect { @Override public String getTableTypeString() { return "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE utf8mb4_unicode_ci"; } }
配置hibernate.dialect
spring: jpa: properties: hibernate: dialect: com.xxx.MySQL5InnoDBDialectUtf8mb4
2.2.2 設(shè)置連接初始化SQL
配置Druid連接池,如果為其他連接池,設(shè)置對(duì)應(yīng)的connectionInitSqls即可
DruidConfig.java
@Configuration public class DruidConfig { @Value("${spring.datasource.druid.connection-init-sqls") private List<String> connectionInitSqls; @Bean public DruidDataSource dataSource() { DruidDataSource dataSource = new DruidDataSource(); dataSource.setConnectionInitSqls(connectionInitSqls); return dataSource; } }
application.yml
spring: datasource: druid: connection-init-sqls: ["SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci"]
最后按上述設(shè)置Spring Data Jpa 生成的表、字段就會(huì)是utf8mb4,utf8mb4_unicode_ci
PS: mysql.url還是需要設(shè)置characterEncoding=utf8不然會(huì)出現(xiàn)中文亂碼
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JPA之映射mysql text類(lèi)型的問(wèn)題
- Springboot2.0配置JPA多數(shù)據(jù)源連接兩個(gè)mysql數(shù)據(jù)庫(kù)方式
- Spring boot基于JPA訪(fǎng)問(wèn)MySQL數(shù)據(jù)庫(kù)的實(shí)現(xiàn)
- 解決springboot的JPA在Mysql8新增記錄失敗的問(wèn)題
- springboot使用spring-data-jpa操作MySQL數(shù)據(jù)庫(kù)
- Spring-Data-JPA整合MySQL和配置的方法
- SpringBoot連接MYSQL數(shù)據(jù)庫(kù)并使用JPA進(jìn)行操作
- Spring Boot 添加MySQL數(shù)據(jù)庫(kù)及JPA實(shí)例
- 在JPA項(xiàng)目啟動(dòng)時(shí)如何新增MySQL字段
相關(guān)文章
Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(33)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-07-07Java監(jiān)聽(tīng)器ActionListener與MouseListener的執(zhí)行順序說(shuō)明
這篇文章主要介紹了Java監(jiān)聽(tīng)器ActionListener與MouseListener的執(zhí)行順序說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12基于Java代碼實(shí)現(xiàn)判斷春節(jié)、端午節(jié)、中秋節(jié)等法定節(jié)假日的方法
這篇文章主要介紹了基于Java代碼實(shí)現(xiàn)判斷春節(jié)、端午節(jié)、中秋節(jié)等法定節(jié)假日的方法 的相關(guān)資料,需要的朋友可以參考下2016-01-01java模擬實(shí)現(xiàn)斗地主發(fā)牌小程序
這篇文章主要為大家詳細(xì)介紹了java模擬實(shí)現(xiàn)斗地主發(fā)牌小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04Java中OkHttp 超時(shí)設(shè)置的實(shí)現(xiàn)
超時(shí)設(shè)置是網(wǎng)絡(luò)編程中不可忽視的一部分,本文就來(lái)介紹一下Java中OkHttp 超時(shí)設(shè)置的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06Spring Boot 校驗(yàn)用戶(hù)上傳的圖片文件(兩種方式)
圖片上傳是現(xiàn)代應(yīng)用中非常常見(jiàn)的一種功能,也是風(fēng)險(xiǎn)比較高的一個(gè)地方,惡意用戶(hù)可能會(huì)上傳一些病毒、木馬,本文給大家介紹兩種對(duì)圖片文件進(jìn)行校驗(yàn)的方法,感興趣的朋友一起看看吧2023-11-11MyBatis在Spring環(huán)境下的事務(wù)管理
MyBatis的設(shè)計(jì)思想很簡(jiǎn)單,可以看做是對(duì)JDBC的一次封裝,并提供強(qiáng)大的動(dòng)態(tài)SQL映射功能。這篇文章主要介紹了MyBatis在Spring環(huán)境下的事務(wù)管理 ,需要的朋友可以參考下2019-07-07Springmvc項(xiàng)目web.xml中servlet-mapping路徑映射配置注意說(shuō)明
這篇文章主要介紹了Springmvc項(xiàng)目web.xml中servlet-mapping路徑映射配置注意說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12