Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
1 問題:數(shù)據(jù)庫(kù)字符集和排序規(guī)則不一致
最近需要向一個(gè)已有的數(shù)據(jù)庫(kù)進(jìn)行擴(kuò)充(已有數(shù)據(jù)庫(kù)是由PHP建的,后來由Java進(jìn)行擴(kuò)展),但是出現(xiàn)了新表和舊表無(wú)法建立外鍵的問題,后來發(fā)現(xiàn)是因?yàn)榫幋a問題,服務(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 | (客戶端來源數(shù)據(jù)使用的字符集) |
| character_set_connection | (連接層字符集) |
| character_set_database | (當(dāng)前選中數(shù)據(jù)庫(kù)的默認(rèn)字符集) |
| character_set_results | (查詢結(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ī)則
重寫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類型的問題
- Springboot2.0配置JPA多數(shù)據(jù)源連接兩個(gè)mysql數(shù)據(jù)庫(kù)方式
- Spring boot基于JPA訪問MySQL數(shù)據(jù)庫(kù)的實(shí)現(xiàn)
- 解決springboot的JPA在Mysql8新增記錄失敗的問題
- 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)文章
MyBatis 如何簡(jiǎn)化的 JDBC(思路詳解)
MyBatis 是一個(gè) 持久層 框架,用于 簡(jiǎn)化JDBC開發(fā),這篇文章主要介紹了MyBatis 如何簡(jiǎn)化的 JDBC(思路詳解),需要的朋友可以參考下2023-03-03
一篇文章了解Jackson注解@JsonFormat及失效解決辦法
這篇文章主要給大家介紹了關(guān)于如何通過一篇文章了解Jackson注解@JsonFormat及失效解決辦法的相關(guān)資料,@JsonFormat注解是一個(gè)時(shí)間格式化注解,用于格式化時(shí)間,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11
Java語(yǔ)法中Lambda表達(dá)式無(wú)法拋出異常的解決
這篇文章主要介紹了Java語(yǔ)法中Lambda表達(dá)式無(wú)法拋出異常的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
sharding-jdbc5.0.0實(shí)現(xiàn)分表實(shí)踐
本文主要介紹了sharding-jdbc5.0.0分表實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
SpringBoot實(shí)戰(zhàn)之實(shí)現(xiàn)結(jié)果的優(yōu)雅響應(yīng)案例詳解
這篇文章主要介紹了SpringBoot實(shí)戰(zhàn)之實(shí)現(xiàn)結(jié)果的優(yōu)雅響應(yīng)案例詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
spring security中的默認(rèn)登錄頁(yè)源碼跟蹤
原來Spring Security有一個(gè)默認(rèn)的WebSecurityConfigurerAdapter,發(fā)現(xiàn)其中有一個(gè)init方法,于是在這個(gè)方法打了斷點(diǎn),在應(yīng)用啟動(dòng)的時(shí)候進(jìn)行跟蹤,這篇文章主要介紹了spring security之 默認(rèn)登錄頁(yè)源碼跟蹤,需要的朋友可以參考下2021-11-11
SpringMVC 中配置 Swagger 插件的教程(分享)
下面小編就為大家分享一篇SpringMVC 中配置 Swagger 插件的教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12
Java項(xiàng)目中獲取路徑的絕對(duì)路徑問題和相對(duì)路徑問題
這篇文章主要介紹了如何Java項(xiàng)目中獲取文件地址,在 Java 項(xiàng)目中我們經(jīng)常會(huì)讀取配置文件,但是文件的路徑在獲取時(shí)我們是怎么得到的?下面我們就一起進(jìn)入文章學(xué)習(xí)該內(nèi)容吧,需要的朋友可以參考下2022-02-02

