亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2018年11月06日 10:25:54   作者:Ho-jian  
這篇文章主要介紹了Spring Data Jpa Mysql使用utf8mb4編碼的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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ù),檢查變量

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

必須保證

系統(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java實(shí)例講解反射機(jī)制是怎么一回事

    Java實(shí)例講解反射機(jī)制是怎么一回事

    Java的反射(reflection)機(jī)制是指在程序的運(yùn)行狀態(tài)中,可以構(gòu)造任意一個(gè)類(lèi)的對(duì)象,可以了解任意一個(gè)對(duì)象所屬的類(lèi),可以了解任意一個(gè)類(lèi)的成員變量和方法,可以調(diào)用任意一個(gè)對(duì)象的屬性和方法
    2022-03-03
  • Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(33)

    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-07
  • Java監(jiān)聽(tīng)器ActionListener與MouseListener的執(zhí)行順序說(shuō)明

    Java監(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é)假日的方法

    這篇文章主要介紹了基于Java代碼實(shí)現(xiàn)判斷春節(jié)、端午節(jié)、中秋節(jié)等法定節(jié)假日的方法 的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • java模擬實(shí)現(xiàn)斗地主發(fā)牌小程序

    java模擬實(shí)現(xiàn)斗地主發(fā)牌小程序

    這篇文章主要為大家詳細(xì)介紹了java模擬實(shí)現(xiàn)斗地主發(fā)牌小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • Java中OkHttp 超時(shí)設(shè)置的實(shí)現(xiàn)

    Java中OkHttp 超時(shí)設(shè)置的實(shí)現(xiàn)

    超時(shí)設(shè)置是網(wǎng)絡(luò)編程中不可忽視的一部分,本文就來(lái)介紹一下Java中OkHttp 超時(shí)設(shè)置的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06
  • Spring Boot 校驗(yàn)用戶(hù)上傳的圖片文件(兩種方式)

    Spring Boot 校驗(yàn)用戶(hù)上傳的圖片文件(兩種方式)

    圖片上傳是現(xiàn)代應(yīng)用中非常常見(jiàn)的一種功能,也是風(fēng)險(xiǎn)比較高的一個(gè)地方,惡意用戶(hù)可能會(huì)上傳一些病毒、木馬,本文給大家介紹兩種對(duì)圖片文件進(jìn)行校驗(yàn)的方法,感興趣的朋友一起看看吧
    2023-11-11
  • MyBatis在Spring環(huán)境下的事務(wù)管理

    MyBatis在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-07
  • 一文掌握J(rèn)ava的工具類(lèi)和API

    一文掌握J(rèn)ava的工具類(lèi)和API

    在Java中,工具類(lèi)通常包含一系列靜態(tài)方法,用于執(zhí)行常見(jiàn)的任務(wù),這些任務(wù)可能不直接關(guān)聯(lián)到特定的業(yè)務(wù)邏輯,而是用于處理一些基礎(chǔ)的數(shù)據(jù)轉(zhuǎn)換、字符串操作、文件操作等,這篇文章主要介紹了一文搞懂Java的工具類(lèi)和API,需要的朋友可以參考下
    2008-01-01
  • Springmvc項(xiàng)目web.xml中servlet-mapping路徑映射配置注意說(shuō)明

    Springmvc項(xiàng)目web.xml中servlet-mapping路徑映射配置注意說(shuō)明

    這篇文章主要介紹了Springmvc項(xiàng)目web.xml中servlet-mapping路徑映射配置注意說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評(píng)論