Flask接口签名sign原理与实例代码浅析
727
2023-01-19
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_connectirzUiOXeAon
(连接层字符集)
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
@Bean
public DruidDataSource dataSource() {
DruidDataSourhttp://ce 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不然会出现中文乱码
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~