Class ReadingMetadataSpec
- java.lang.Object
-
- org.apache.flink.table.planner.plan.abilities.source.SourceAbilitySpecBase
-
- org.apache.flink.table.planner.plan.abilities.source.ReadingMetadataSpec
-
- All Implemented Interfaces:
SourceAbilitySpec
public final class ReadingMetadataSpec extends SourceAbilitySpecBase
A sub-class ofSourceAbilitySpec
that can not only serialize/deserialize the metadata columns to/from JSON, but also can read the metadata columns fromSupportsReadingMetadata
.
-
-
Field Summary
Fields Modifier and Type Field Description static String
FIELD_NAME_METADATA_KEYS
-
Fields inherited from class org.apache.flink.table.planner.plan.abilities.source.SourceAbilitySpecBase
FIELD_NAME_PRODUCED_TYPE
-
-
Constructor Summary
Constructors Constructor Description ReadingMetadataSpec(List<String> metadataKeys, RowType producedType)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
apply(DynamicTableSource tableSource, SourceAbilityContext context)
Apply the ability to the givenDynamicTableSource
.boolean
equals(Object o)
String
getDigests(SourceAbilityContext context)
Additional digests to generate when this spec is applied to the source.List<String>
getMetadataKeys()
int
hashCode()
boolean
needAdjustFieldReferenceAfterProjection()
Does this spec needs adjust field reference after projection.-
Methods inherited from class org.apache.flink.table.planner.plan.abilities.source.SourceAbilitySpecBase
getProducedType
-
-
-
-
Field Detail
-
FIELD_NAME_METADATA_KEYS
public static final String FIELD_NAME_METADATA_KEYS
- See Also:
- Constant Field Values
-
-
Method Detail
-
apply
public void apply(DynamicTableSource tableSource, SourceAbilityContext context)
Description copied from interface:SourceAbilitySpec
Apply the ability to the givenDynamicTableSource
.
-
needAdjustFieldReferenceAfterProjection
public boolean needAdjustFieldReferenceAfterProjection()
Description copied from interface:SourceAbilitySpec
Does this spec needs adjust field reference after projection. If the spec containsRexNode
or references fields in scan table, the referenced field indices maybe changed after projection pushdown with scan reuse. Under such case, this method need to return true to notify planner doesn't reuse the scan.
-
getDigests
public String getDigests(SourceAbilityContext context)
Description copied from interface:SourceAbilitySpec
Additional digests to generate when this spec is applied to the source.- Parameters:
context
- The context about the source.
-
equals
public boolean equals(Object o)
- Overrides:
equals
in classSourceAbilitySpecBase
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classSourceAbilitySpecBase
-
-