开发者社区 > 大数据与机器学习 > 实时计算 Flink > 正文

咨询下各位大佬,用Flink CDC 2.2.0同步MYSQL数据库,库表是latin1编码的时候?

咨询下各位大佬,用Flink CDC 2.2.0同步MYSQL数据库,库表是latin1编码的时候,读取出来的中文会是乱码,这个有什么解决方法吗?是不是SnapshotReader和BinlogSplitReader读取字符类型数据的方式也不太一样的?

展开
收起
真的很搞笑 2023-08-01 14:03:03 54 0
1 条回答
写回答
取消 提交回答
  • 在 MySQL 数据库中创建一个新的编码为 utf8 的表。
    在 Flink CDC 的配置中,指定 table.schema.case.insensitive = true。
    在 Flink CDC 的配置中,指定 table.default.column.types = 'STRING'。
    这样,Flink CDC 就可以正确地读取 latin1 编码的表的数据了。

    注意:如果 MySQL 数据库中的表是 latin1 编码,那么 Flink CDC 只能读取 varchar 类型的数据。如果想读取其他类型的数据,需要将表的数据类型转换为 varchar 类型。

    2023-09-25 18:01:18
    赞同 展开评论 打赏

实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。

相关产品

  • 实时计算 Flink版
  • 相关电子书

    更多
    Flink CDC Meetup PPT - 龚中强 立即下载
    Flink CDC Meetup PPT - 王赫 立即下载
    Flink CDC Meetup PPT - 覃立辉 立即下载