子类化Avro记录?

 xpf 发布于 2023-02-04 18:43

我有两种类型的AvroRecords,它们都扩展了avro.SpecificRecord.有没有办法让一个人成为另一个Java的子类?其中一个是PersonRecord,我希望它的子类是EmployeeRecord.我不想用avro数据填充普通Java类的原因是我使用hadoop并且如果可能的话希望直接使用avro文件.

为了澄清,我感兴趣的是多态性.我希望能够使用一个函数,将PersonRecord作为参数与EmployeeRecord.

谢谢!

1 个回答
  • 我想我明白你要做什么("Avro Schema定义文件中的Avro记录的子类"),但我不认为这是可能的.

    相反,一种方法是将EmployeeRecord一个PersonRecord成员嵌套在其中,然后是以下与Employee特定相关的信息.例如 :

    { 
      "type": "record",
      "name": "PersonRecord",
      "namespace": "com.yourapp",
      "fields": [
        {
          "name": "first",
          "type": "string"
        },
        { etc... }
        ]
    }
    
    
    { 
      "type": "record",
      "name": "EmployeeRecord",
      "namespace": "com.yourapp",
      "fields": [
        {
          "name": "PersonInfo",
          "type": "PersonRecord"
        },
        { 
          "name": "salary",
          "type": "int"
         },
        { etc... }
        ]
    }
    

    2023-02-04 18:46 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有