使用GenericRecord在Avro中填充嵌套记录的问题

11

假设我有以下模式:

{
 "name" : "Profile",
 "type" : "record",
 "fields" : [
  { "name" : "firstName", "type" : "string" },
  { "name" : "address" , "type" : {
   "type" : "record",
   "name" : "AddressUSRecord",
   "fields" : [
    { "name" : "address1" , "type" : "string" },
    { "name" : "address2" , "type" : "string" },
    { "name" : "city" , "type" : "string" },
    { "name" : "state" , "type" : "string" },
    { "name" : "zip" , "type" : "int" },
    { "name" : "zip4", "type": "int" }
   ]
  }
 }
]
}

我使用一个 GenericRecord 来表示每个创建的 Profile。要添加 firstName,可以轻松执行以下操作:

Schema  sch =  Schema.parse(schemaFile);
DataFileWriter<GenericRecord> fw = new DataFileWriter<GenericRecord>(new GenericDatumWriter<GenericRecord>()).create(sch, new File(outFile));
GenericRecord r = new GenericData.Record(sch);
r.put(“firstName”, “John”);
fw.append(r);

但是我该如何设置城市呢?比如说,我要怎样将这个键表示为一个字符串,以便 r.put 方法可以理解呢?

谢谢。

1个回答

23
对于上述模式:
GenericRecord t = new GenericData.Record(sch.getField("address").schema());
t.put("city","beijing");
r.put("address",t);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接