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

 更新时间:2018年11月06日 10:25:54   作者:Ho-jian  
这篇文章主要介绍了Spring Data Jpa Mysql使用utf8mb4编码的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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查找。修改下面三部分

[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

@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"]

最后按上述设置Spring Data Jpa 生成的表、字段就会是utf8mb4,utf8mb4_unicode_ci

PS: mysql.url还是需要设置characterEncoding=utf8不然会出现中文乱码

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

相关文章

  • MyBatis 如何简化的 JDBC(思路详解)

    MyBatis 如何简化的 JDBC(思路详解)

    MyBatis 是一个 持久层 框架,用于 简化JDBC开发,这篇文章主要介绍了MyBatis 如何简化的 JDBC(思路详解),需要的朋友可以参考下
    2023-03-03
  • 一篇文章了解Jackson注解@JsonFormat及失效解决办法

    一篇文章了解Jackson注解@JsonFormat及失效解决办法

    这篇文章主要给大家介绍了关于如何通过一篇文章了解Jackson注解@JsonFormat及失效解决办法的相关资料,@JsonFormat注解是一个时间格式化注解,用于格式化时间,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • Java语法中Lambda表达式无法抛出异常的解决

    Java语法中Lambda表达式无法抛出异常的解决

    这篇文章主要介绍了Java语法中Lambda表达式无法抛出异常的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • sharding-jdbc5.0.0实现分表实践

    sharding-jdbc5.0.0实现分表实践

    本文主要介绍了sharding-jdbc5.0.0分表实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Mybatis-plus null值更新不生效问题解决

    Mybatis-plus null值更新不生效问题解决

    在使用Mybatis-plus进行数据更新时,默认策略是NOT_NULL,即null值不会被更新到数据库,解决方法包括设置全局field-strategy、对特定字段设置field-strategy或使用UpdateWrapper方式更新,下面就来介绍一下
    2024-10-10
  • SpringBoot实战之实现结果的优雅响应案例详解

    SpringBoot实战之实现结果的优雅响应案例详解

    这篇文章主要介绍了SpringBoot实战之实现结果的优雅响应案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • spring security中的默认登录页源码跟踪

    spring security中的默认登录页源码跟踪

    原来Spring Security有一个默认的WebSecurityConfigurerAdapter,发现其中有一个init方法,于是在这个方法打了断点,在应用启动的时候进行跟踪,这篇文章主要介绍了spring security之 默认登录页源码跟踪,需要的朋友可以参考下
    2021-11-11
  • SpringMVC 中配置 Swagger 插件的教程(分享)

    SpringMVC 中配置 Swagger 插件的教程(分享)

    下面小编就为大家分享一篇SpringMVC 中配置 Swagger 插件的教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • Java项目中获取路径的绝对路径问题和相对路径问题

    Java项目中获取路径的绝对路径问题和相对路径问题

    这篇文章主要介绍了如何Java项目中获取文件地址,在 Java 项目中我们经常会读取配置文件,但是文件的路径在获取时我们是怎么得到的?下面我们就一起进入文章学习该内容吧,需要的朋友可以参考下
    2022-02-02
  • java中BigDecimal的操作方法

    java中BigDecimal的操作方法

    这篇文章主要介绍了java中BigDecimal的操作方法,较为详细的分析了BigDecimal类在进行商业计算时的应用方法,精度以及注意事项等问题,需要的朋友可以参考下
    2014-12-12

最新评论