麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > Java > 正文

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

2024-07-14 08:42:45
字體:
供稿:網(wǎng)友

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

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

2 解決方法

2.1 將本地數(shù)據(jù)庫改成utf8mb4,utf8mb4_unicode_ci

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

 

復制代碼代碼如下:
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 (當前選中數(shù)據(jù)庫的默認字符集)
character_set_results (查詢結(jié)果字符集)
character_set_server (默認的內(nèi)部操作字符集)

 

這幾個變量必須是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

如果我不想修改本地數(shù)據(jù)庫呢?那就用下面這種方法。(我用的是第二種)

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

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

@Configurationpublic 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)中文亂碼

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久人人爽人人爽人人片av免费 | 一区二区三区欧美在线观看 | 视频在线亚洲 | 亚洲二区免费 | 91精品国产一区二区在线观看 | 伊人一二三四区 | 日韩欧美视频一区二区三区 | 亚洲成人精品一区二区 | 久久久久久久亚洲精品 | 亚洲成人入口 | 欧美一级黑人 | 久久一区国产 | 羞羞网站入口 | 久久国产一二区 | 国产成人高清成人av片在线看 | 国产精品久久久久久婷婷天堂 | 毛片免费视频观看 | 欧美成人性生活 | 美女视频免费一区二区 | 国产成人高清在线观看 | 91av国产在线 | 草草影院地址 | 日韩av有码在线 | 看国产精品| 好吊色欧美一区二区三区四区 | 精品成人免费视频 | 男男羞羞视频网站国产 | 久久久久久久久久久av | 免费毛片免费看 | 亚洲成人免费电影 | 国产精品免费成人 | 亚洲综合视频一区 | 国产精品久久久久久模特 | 特级a欧美做爰片毛片 | 亚洲一区二区三区日本久久九 | 一区二区三区无码高清视频 | 成人免费一区二区三区视频网站 | 日本成人一区二区三区 | 成人毛片100免费观看 | 中文字幕1区2区 | 天堂成人国产精品一区 |