开发者社区 > 大数据与机器学习 > 大数据开发治理DataWorks > 正文

问:数据库同步表情符报错... ID=mCvVPH4B1r73GMJAKlLw INDEX=1

问:数据库同步表情符报错... ID=mCvVPH4B1r73GMJAKlLw INDEX=1

展开
收起
十一0204 2023-04-05 09:09:10 184 0
1 条回答
写回答
取消 提交回答
  • 意中人就是我呀!

    2000元阿里云代金券免费领取,2核4G云服务器仅799元/3年,新老用户都有优惠,立即抢购>>>

    "如果数据中包括表情符,在同步过程中可能会报错脏数据:[13350975-0-0-writer] ERROR StdoutPluginCollector - 脏数据 {""exception"":""Incorrect string value: '\xF0\x9F\x98\x82\xE8\xA2...' for column 'introduction' at row 1"",""record"":[{""byteSize"":8,""index"":0,""rawData"":9642,""type"":""LONG""},}],""type"":""writer""} 。可能原因:数据库相关编码未设置为utf8mb4,导致同步表情符报错。源端的数据本身就是乱码。数据库和客户端的编码不一样。浏览器编码不一样,导致预览失败或乱码。解决方案: 针对产生乱码的不同原因,选择相应的解决方法:如果您的原始数据乱码,需首先处理好原始数据,再进行同步任务。数据库和客户端编码格式不一致,需先修改编码格式。浏览器编码和数据库或客户端编码格式不一致,需先统一编码格式,然后进行数据预览。您可以尝试以下操作:JDBC格式添加的数据源修改utf8mb4:jdbc:mysql://xxx.x.x.x:3306/database?com.mysql.jdbc.faultInjection.serverCharsetIndex=45。 实例ID形式添加数据源:在数据库名后拼接,格式为database?com.mysql.jdbc.faultInjection.serverCharsetIndex=45。修改数据库相关的编码格式为utf8mb4。例如,在RDS控制台修改RDS的数据库编码格式。说明 设置RDS数据源编码格式命令:set names utf8mb4。查看RDS数据库编码格式命令: show variables like 'char%'。 https://help.aliyun.com/document_detail/146663.html 此回答整理自钉群“DataWorks交流群(答疑@机器人)”"

    2023-04-05 12:59:39
    赞同 展开评论 打赏

DataWorks基于MaxCompute/Hologres/EMR/CDP等大数据引擎,为数据仓库/数据湖/湖仓一体等解决方案提供统一的全链路大数据开发治理平台。

相关电子书

更多
2022 DTCC-阿里云一站式数据库上云最佳实践 立即下载
云时代的数据库技术趋势 立即下载
超大型金融机构国产数据库全面迁移成功实践 立即下载
http://www.vxiaotou.com