时间:2021-05-20
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查找。修改下面三部分
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()
配置hibernate.dialect
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不然会出现中文乱码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、简介MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是mostbytes4的意思,专门用来兼容四字节的unicode。好在utf8mb4是
utf8mb4编码是utf8编码的超集,兼容utf8,并且能存储4字节的表情字符。采用utf8mb4编码的好处是:存储与获取数据的时候,不用再考虑表情字符的编码
MySQL需要支持emoji表情符号版本需要大于5.5.3,且字符集需要设置为utf8mb4字符集。utf8mb4和utf8到底有什么区别呢?原来以往的mysq
我在用mysql保存微信昵称,当插入昵称数据的时候,报错。于是做了如下工作:一、简介MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most
前言其实之前使用yum安装MySQL确实很方便,但是默认安装的myql5.0版本的,不支持utf8mb4(utf8mb4扩展到一个字符最多能有4节,所以能支持更