溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼

發(fā)布時(shí)間:2020-10-21 15:36:20 來源:腳本之家 閱讀:291 作者:Ho-jian 欄目:編程語言

1 問題:數(shù)據(jù)庫字符集和排序規(guī)則不一致

最近需要向一個(gè)已有的數(shù)據(jù)庫進(jìn)行擴(kuò)充(已有數(shù)據(jù)庫是由PHP建的,后來由Java進(jìn)行擴(kuò)展),但是出現(xiàn)了新表和舊表無法建立外鍵的問題,后來發(fā)現(xiàn)是因?yàn)榫幋a問題,服務(wù)器數(shù)據(jù)庫和我本地?cái)?shù)據(jù)庫的字符集和排序規(guī)則不對應(yīng),服務(wù)器數(shù)據(jù)庫使用的是utf8mb4,utf8mb4_unicode_ci而我本地使用的是utf8,utf8_general_ci。

2 解決方法

2.1 將本地?cái)?shù)據(jù)庫改成utf8mb4,utf8mb4_unicode_ci

該方法參考: 更改MySQL數(shù)據(jù)庫的編碼為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ù)庫,檢查變量

復(fù)制代碼 代碼如下:
SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';

必須保證

系統(tǒng)變量 描述
character_set_client (客戶端來源數(shù)據(jù)使用的字符集)
character_set_connection (連接層字符集)
character_set_database (當(dāng)前選中數(shù)據(jù)庫的默認(rèn)字符集)
character_set_results (查詢結(jié)果字符集)
character_set_server (默認(rèn)的內(nèi)部操作字符集)

這幾個(gè)變量必須是utf8mb4。

2.1.3 將已經(jīng)建好的數(shù)據(jù)庫、表和列轉(zhuǎn)換成utf8mb4,utf8mb4_unicode_ci

更改數(shù)據(jù)庫編碼: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ù)庫呢?那就用下面這種方法。(我用的是第二種)

2.2 在Spring Boot中配置,不修改本地?cái)?shù)據(jù)庫

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è)置對應(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 生成的表、字段就會是utf8mb4,utf8mb4_unicode_ci

PS: mysql.url還是需要設(shè)置characterEncoding=utf8不然會出現(xiàn)中文亂碼

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(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)容。

AI