服务器之家

服务器之家 > 正文

Spring Data Jpa Mysql使用utf8mb4编码的示例代码

时间:2021-06-10 15:04     来源/作者:Ho-jian

1 问题:数据库字符集和排序规则不一致

最近需要向一个已有的数据库进行扩充(已有数据库是由php建的,后来由java进行扩展),但是出现了新表和旧表无法建立外键的问题,后来发现是因为编码问题,服务器数据库和我本地数据库的字符集和排序规则不对应,服务器数据库使用的是utf8mb4,utf8mb4_unicode_ci而我本地使用的是utf8,utf8_general_ci。

2 解决方法

2.1 将本地数据库改成utf8mb4,utf8mb4_unicode_ci

该方法参考: 更改mysql数据库的编码为utf8mb4

2.1.1 找到my.cnf,一般在/etc/mysql/my.cnf,可以用locate my.cnf查找。修改下面三部分

?
1
2
3
4
5
6
7
8
9
[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()

?
1
2
3
4
5
6
public class mysql5innodbdialectutf8mb4 extends mysql5innodbdialect {
  @override
  public string gettabletypestring() {
    return "engine=innodb default charset=utf8mb4 collate utf8mb4_unicode_ci";
  }
}

配置hibernate.dialect

?
1
2
3
4
5
spring:
 jpa:
  properties:
   hibernate:
    dialect: com.xxx.mysql5innodbdialectutf8mb4

2.2.2 设置连接初始化sql

配置druid连接池,如果为其他连接池,设置对应的connectioninitsqls即可

druidconfig.java

?
1
2
3
4
5
6
7
8
9
10
11
12
@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

?
1
2
3
4
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不然会出现中文乱码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/hhaojian/article/details/79243763

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部