Package org.apache.iceberg.flink.sink
Class AvroGenericRecordToRowDataMapper
java.lang.Object
org.apache.iceberg.flink.sink.AvroGenericRecordToRowDataMapper
- All Implemented Interfaces:
- Serializable,- org.apache.flink.api.common.functions.Function,- org.apache.flink.api.common.functions.MapFunction<org.apache.avro.generic.GenericRecord,- org.apache.flink.table.data.RowData> 
public class AvroGenericRecordToRowDataMapper
extends Object
implements org.apache.flink.api.common.functions.MapFunction<org.apache.avro.generic.GenericRecord,org.apache.flink.table.data.RowData> 
This util class converts Avro GenericRecord to Flink RowData. 
 
Internally it uses Flink
Internally it uses Flink
AvroToRowDataConverters. Because of the precision difference
 between how Iceberg schema (micro) and Flink AvroToRowDataConverters (milli) deal with
 time type, we can't directly use the Avro Schema converted from Iceberg schema via AvroSchemaUtil.convert(org.apache.iceberg.Schema, String).- See Also:
- 
Method SummaryModifier and TypeMethodDescriptionforAvroSchema(org.apache.avro.Schema avroSchema) Create a mapper based on Avro schema.org.apache.flink.table.data.RowDatamap(org.apache.avro.generic.GenericRecord genericRecord) 
- 
Method Details- 
mappublic org.apache.flink.table.data.RowData map(org.apache.avro.generic.GenericRecord genericRecord) throws Exception - Specified by:
- mapin interface- org.apache.flink.api.common.functions.MapFunction<org.apache.avro.generic.GenericRecord,- org.apache.flink.table.data.RowData> 
- Throws:
- Exception
 
- 
forAvroSchemaCreate a mapper based on Avro schema.
 
-