【大数据学习笔记-4】电商数据从阿里云RDS数据库复制到华为云RDS数据库,部分表格复制失败

【问题背景】

昨天用华为云CDM服务把阿里云上一个电商客户RDS mysql数据库复制到华为云上备份,提示有部分数据表复制失败了。

【原因分析】

通过华为云迁移服务CDM发现了哪些表格迁移失败,能看到是完成复制了多少行。

进一步查看日志,发现有个字符是4字节的。根据经验,推测是移动APP的emoji表情。

检查数据库的字符编码是utf-8,在数据库中占用3个字节,因此4字节的汉字就无法存储,导致了数据库报错。

查询命令:show variables like 'character_set_database'

 

解决办法:

1、将数据库的编码格式由utf8改为utf8mb4

2、重新触发迁移。

 

测试结果:

1、在华为云RDS实例中重新建一个数据库,编码格式为utf8mb4,校验规则utf8mb4_bin。如果是改的数据库编码,可能需要重重启才生效。

2、华为云CDM迁移设置界面的 本地加速API关闭。

2、CDM再次迁移正常。

 

 

。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值