AvroUnion的JSON数据映射问题。
创始人
2024-11-13 08:30:04
0
  1. 定义 Avro Schema 时,使用 Union 类型。比如下面这个例子中,name 字段可以是字符串类型,也可以是 null 类型:
{
    "type": "record",
    "name": "Person",
    "fields": [
        {"name": "name", "type": ["string", "null"]},
        {"name": "age", "type": "int"}
    ]
}
  1. 传递 JSON 数据时,使用 Avro 的 JSON 编码规则。比如下面这个例子中,name 字段是否为 null 通过缺失来表示,而不是使用值为 null 的属性:
{
    "name": "John",
    "age": 25
}

如果 name 字段为 null,则这个属性应该省略不传,而不是写成 "name": null

  1. 在代码中,使用 Avro 的 DataFileReader 或 GenericData.parseReader 方法解析 JSON 数据。具体示例代码如下:
// 读取 Avro schema 文件
Schema schema = new Schema.Parser().parse(new File("person.avsc"));

// 读取 JSON 数据文件
File file = new File("person.json");
DataFileReader reader = new DataFileReader<>(file, new GenericDatumReader<>(schema));

// 遍历数据
while (reader.hasNext()) {
    GenericRecord record = reader.next();
    String name = (String) record.get("name");
    Integer age = (Integer) record.get("age");

    // 处理记录
    System.out.println("Name: " + name);
    System.out.println("Age: " + age);
}

相关内容

热门资讯

七分钟辅助!丽水茶苑苹果手机辅... 七分钟辅助!丽水茶苑苹果手机辅助,本来是真的有辅助教程(有挂方式)1、实时丽水茶苑苹果手机辅助透视辅...
第一分钟辅助!闲来辅助神器下载... 第一分钟辅助!闲来辅助神器下载2022,好像真的有辅助方法(有挂教程)1、不需要AI权限,帮助你快速...
九分钟辅助!丽水都莱辅助工具试... 九分钟辅助!丽水都莱辅助工具试用,确实存在有辅助神器(有挂方法)九分钟辅助!丽水都莱辅助工具试用,确...
第一分钟辅助!蛮王辅助器,好像... 第一分钟辅助!蛮王辅助器,好像是有辅助方法(有挂教学)1、首先打开蛮王辅助器辅助器下载最新版本,在蛮...
第六分钟辅助!潮汕汇挂,一贯真... 第六分钟辅助!潮汕汇挂,一贯真的是有辅助插件(有挂辅助)1、这是跨平台的潮汕汇挂轻量版有透视,在线的...
六分钟辅助!微信开心泉州辅助器... 六分钟辅助!微信开心泉州辅助器,一直有辅助器(有挂教学)1、下载好微信开心泉州辅助器透视辅助下载之后...
第3分钟辅助!佛手十三道破解版... 第3分钟辅助!佛手十三道破解版安卓,竟然真的有辅助攻略(有挂存在)1、让任何用户在无需佛手十三道破解...
2分钟辅助!sohoo竞技联盟... 2分钟辅助!sohoo竞技联盟辅助,切实真的有辅助脚本(有挂技术)1.sohoo竞技联盟辅助 选牌创...
第8分钟辅助!心悦手游辅助器,... 第8分钟辅助!心悦手游辅助器,原来真的是有辅助技巧(确实有挂);1、每一步都需要思考,不同水平的挑战...
第十分钟辅助!广东雀神祈福真的... 第十分钟辅助!广东雀神祈福真的有用吗,都是是有辅助技巧(有挂方略)1、下载好广东雀神祈福真的有用吗透...