Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼
1 問題:數(shù)據庫字符集和排序規(guī)則不一致
最近需要向一個已有的數(shù)據庫進行擴充(已有數(shù)據庫是由PHP建的,后來由Java進行擴展),但是出現(xiàn)了新表和舊表無法建立外鍵的問題,后來發(fā)現(xiàn)是因為編碼問題,服務器數(shù)據庫和我本地數(shù)據庫的字符集和排序規(guī)則不對應,服務器數(shù)據庫使用的是utf8mb4,utf8mb4_unicode_ci而我本地使用的是utf8,utf8_general_ci。
2 解決方法
2.1 將本地數(shù)據庫改成utf8mb4,utf8mb4_unicode_ci
該方法參考: 更改MySQL數(shù)據庫的編碼為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ù)據庫,檢查變量
必須保證
系統(tǒng)變量 | 描述 |
---|---|
character_set_client | (客戶端來源數(shù)據使用的字符集) |
character_set_connection | (連接層字符集) |
character_set_database | (當前選中數(shù)據庫的默認字符集) |
character_set_results | (查詢結果字符集) |
character_set_server | (默認的內部操作字符集) |
這幾個變量必須是utf8mb4。
2.1.3 將已經建好的數(shù)據庫、表和列轉換成utf8mb4,utf8mb4_unicode_ci
更改數(shù)據庫編碼: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
如果我不想修改本地數(shù)據庫呢?那就用下面這種方法。(我用的是第二種)
2.2 在Spring Boot中配置,不修改本地數(shù)據庫
2.2.1 在JPA建表時設置表的編碼和排序規(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 設置連接初始化SQL
配置Druid連接池,如果為其他連接池,設置對應的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"]
最后按上述設置Spring Data Jpa 生成的表、字段就會是utf8mb4,utf8mb4_unicode_ci
PS: mysql.url還是需要設置characterEncoding=utf8不然會出現(xiàn)中文亂碼
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java監(jiān)聽器ActionListener與MouseListener的執(zhí)行順序說明
這篇文章主要介紹了Java監(jiān)聽器ActionListener與MouseListener的執(zhí)行順序說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12基于Java代碼實現(xiàn)判斷春節(jié)、端午節(jié)、中秋節(jié)等法定節(jié)假日的方法
這篇文章主要介紹了基于Java代碼實現(xiàn)判斷春節(jié)、端午節(jié)、中秋節(jié)等法定節(jié)假日的方法 的相關資料,需要的朋友可以參考下2016-01-01Springmvc項目web.xml中servlet-mapping路徑映射配置注意說明
這篇文章主要介紹了Springmvc項目web.xml中servlet-mapping路徑映射配置注意說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12