亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

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

2024-07-14 08:42:45
字體:
來源:轉載
供稿:網友

1 問題:數據庫字符集和排序規則不一致

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

2 解決方法

2.1 將本地數據庫改成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 重啟數據庫,檢查變量

 

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

 

必須保證

 

系統變量 描述
character_set_client (客戶端來源數據使用的字符集)
character_set_connection (連接層字符集)
character_set_database (當前選中數據庫的默認字符集)
character_set_results (查詢結果字符集)
character_set_server (默認的內部操作字符集)

 

這幾個變量必須是utf8mb4。

2.1.3 將已經建好的數據庫、表和列轉換成utf8mb4,utf8mb4_unicode_ci

更改數據庫編碼: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

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

2.2 在Spring Boot中配置,不修改本地數據庫

2.2.1 在JPA建表時設置表的編碼和排序規則

重寫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不然會出現中文亂碼

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


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品一区在线播放| 欧美精品一区二区免费| 日韩成人在线网站| 亚洲精品日韩丝袜精品| 美女999久久久精品视频| 91黄色8090| 欧美俄罗斯性视频| 啪一啪鲁一鲁2019在线视频| 国产日韩视频在线观看| 亚洲午夜av久久乱码| 中文字幕亚洲一区在线观看| 日韩精品中文字幕在线观看| 久久久亚洲福利精品午夜| 日韩av大片免费看| 亚洲精品动漫久久久久| 亚洲欧美日韩精品| 国产在线一区二区三区| 亚洲欧美日韩一区二区在线| 欧美激情在线一区| 国产亚洲欧美aaaa| 欧美激情精品久久久久久变态| 国产成人一区二区三区| 久久在精品线影院精品国产| 欧美日本精品在线| 国产精品精品视频| 国产精品久久久久久久久久久不卡| 在线观看不卡av| 久久av红桃一区二区小说| 日韩精品欧美国产精品忘忧草| 69av在线播放| 久久99久久久久久久噜噜| 自拍偷拍亚洲精品| 夜夜嗨av色一区二区不卡| 色噜噜狠狠狠综合曰曰曰88av| 欧美一区二粉嫩精品国产一线天| 国产精品高潮粉嫩av| 国产日韩欧美一二三区| 两个人的视频www国产精品| 久久免费观看视频| www.久久久久久.com| 久久久久国产精品免费网站| 亚洲欧美综合另类中字| 欧美国产日韩一区二区| 中文字幕日本欧美| 久久精品国产久精国产思思| 5252色成人免费视频| 中文字幕欧美亚洲| 久久天天躁狠狠躁夜夜爽蜜月| 久久久精品一区二区三区| 国内揄拍国内精品| 亚洲日韩第一页| 韩国欧美亚洲国产| 欧美最猛黑人xxxx黑人猛叫黄| 青青草成人在线| 欧美午夜视频一区二区| 久久精品国产久精国产一老狼| 国产一区香蕉久久| 亚洲免费中文字幕| 成人午夜一级二级三级| 久久韩剧网电视剧| 91精品国产综合久久香蕉922| 欧美日韩一区二区在线| 国产成人精品电影久久久| 亚洲**2019国产| 3344国产精品免费看| 永久555www成人免费| 亚洲香蕉伊综合在人在线视看| 欧美成人免费一级人片100| 日韩国产高清视频在线| 91国产精品91| 欧美日韩在线视频一区| 久久影院在线观看| 精品亚洲精品福利线在观看| 美女福利视频一区| 欧美激情videoshd| 亚洲欧美精品一区二区| 欧美一级视频免费在线观看| 成人免费观看a| 日韩美女在线观看| 国产精品久久久久久久一区探花| 久久久国产精品免费| 精品久久久香蕉免费精品视频| 亚洲片在线观看| 亚洲精品久久久久中文字幕欢迎你| 91久久久在线| 日韩高清电影免费观看完整| 热久久免费视频精品| 亚洲欧美日韩图片| 91久久久久久久久久| 欧美黑人巨大xxx极品| 欧美性69xxxx肥| 91精品国产成人| 尤物tv国产一区| 国产一区二区丝袜高跟鞋图片| 欧美最顶级的aⅴ艳星| 色悠悠久久88| 国产91精品不卡视频| 欧美性做爰毛片| 久久精品国产2020观看福利| 亚洲精品视频在线观看视频| 国产精品白嫩美女在线观看| 国产精品久久久av| 欧美国产日本高清在线| 成人免费福利在线| 国产精品678| 精品久久久香蕉免费精品视频| 久久久久成人精品| 国产精品99久久久久久www| 社区色欧美激情 | 久久人人爽人人爽人人片av高请| 成人黄色av免费在线观看| 日韩**中文字幕毛片| 69av成年福利视频| 亚洲国产精品福利| 国产精品ⅴa在线观看h| 国产在线视频2019最新视频| 国产欧美韩国高清| 免费91在线视频| 在线免费看av不卡| 国产精品扒开腿做爽爽爽视频| 久久久久久久久91| 国产精品激情av电影在线观看| 亚洲永久在线观看| 中文字幕精品一区久久久久| 午夜精品久久久久久久99热| 欧美精品久久久久久久| 91九色精品视频| 色小说视频一区| 亚洲一区二区中文| 中文字幕亚洲激情| 91国语精品自产拍在线观看性色| 亚洲精品综合精品自拍| 国产成人综合精品在线| 日韩一区二区欧美| 在线精品国产成人综合| 欧美丝袜一区二区三区| 北条麻妃一区二区三区中文字幕| 久久精品精品电影网| 久久国产天堂福利天堂| 欧美大奶子在线| 久久精品中文字幕电影| 亚洲xxxx妇黄裸体| 国产精品久久久久久影视| 日韩欧美精品网址| 久久精品视频99| 国产91色在线免费| 久久夜色精品亚洲噜噜国产mv| 亚洲美女性生活视频| 中日韩美女免费视频网站在线观看| 久久激情视频免费观看| 国产精品黄色av| 欧美日韩中文字幕日韩欧美| 国产精品香蕉在线观看| 国产成人激情小视频| 91在线色戒在线| 精品高清一区二区三区| 国产视频久久久久| 日韩一区二区三区国产| 国产精品黄视频| 日韩精品日韩在线观看| 日韩高清欧美高清| 欧美精品videos另类日本| 另类少妇人与禽zozz0性伦| 亚洲国产中文字幕在线观看|