Class GenericSqlToStreamOperator
- java.lang.Object
-
- org.apache.wayang.core.plan.wayangplan.OperatorBase
-
- org.apache.wayang.core.plan.wayangplan.UnaryToUnaryOperator<Record,Record>
-
- org.apache.wayang.genericjdbc.operators.GenericSqlToStreamOperator
-
- All Implemented Interfaces:
java.io.Serializable,ActualOperator,ElementaryOperator,ExecutionOperator,Operator,JsonSerializable,JavaExecutionOperator
public class GenericSqlToStreamOperator extends UnaryToUnaryOperator<Record,Record> implements JavaExecutionOperator, JsonSerializable
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.wayang.core.plan.wayangplan.OperatorBase
OperatorBase.GsonSerializer
-
Nested classes/interfaces inherited from interface org.apache.wayang.core.util.JsonSerializable
JsonSerializable.Serializer<T extends JsonSerializable>
-
-
Field Summary
-
Fields inherited from class org.apache.wayang.core.plan.wayangplan.OperatorBase
inputSlots, outputSlots, STANDARD_OPERATOR_ARGS
-
Fields inherited from interface org.apache.wayang.core.util.JsonSerializable
uncheckedSerializer
-
Fields inherited from interface org.apache.wayang.core.plan.wayangplan.Operator
FIRST_EPOCH
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedGenericSqlToStreamOperator(GenericSqlToStreamOperator that)GenericSqlToStreamOperator(GenericJdbcPlatform jdbcPlatform)Creates a new instance.GenericSqlToStreamOperator(GenericJdbcPlatform jdbcPlatform, DataSetType<Record> dataSetType)Creates a new instance.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Tuple<java.util.Collection<ExecutionLineageNode>,java.util.Collection<ChannelInstance>>evaluate(ChannelInstance[] inputs, ChannelInstance[] outputs, JavaExecutor executor, OptimizationContext.OperatorContext operatorContext)Evaluates this operator.static GenericSqlToStreamOperatorfromJson(WayangJsonObj wayangJsonObj)java.util.Collection<java.lang.String>getLoadProfileEstimatorConfigurationKeys()Provide theConfigurationkeys for theLoadProfileEstimatorspecification of this instance.java.util.List<ChannelDescriptor>getSupportedInputChannels(int index)java.util.List<ChannelDescriptor>getSupportedOutputChannels(int index)Display the supportedChannels for a certainOutputSlot.WayangJsonObjtoJson()Convert this instance to aWayangJsonObj.-
Methods inherited from class org.apache.wayang.core.plan.wayangplan.UnaryToUnaryOperator
getInput, getInputType, getOutput, getOutputType
-
Methods inherited from class org.apache.wayang.core.plan.wayangplan.OperatorBase
accept, addBroadcastInput, addTargetPlatform, at, collectMappedInputSlots, collectMappedOutputSlots, copy, createCopy, getAllInputs, getAllOutputs, getCardinalityEstimator, getContainer, getEpoch, getName, getOriginal, getSimpleClassName, getTargetPlatforms, isAuxiliary, isSupportingBroadcastInputs, propagateInputCardinality, propagateOutputCardinality, setAuxiliary, setCardinalityEstimator, setContainer, setEpoch, setName, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.wayang.core.plan.wayangplan.ActualOperator
accept
-
Methods inherited from interface org.apache.wayang.core.plan.wayangplan.ElementaryOperator
createCardinalityEstimator, getCardinalityEstimator, isAuxiliary, setAuxiliary, setCardinalityEstimator
-
Methods inherited from interface org.apache.wayang.core.plan.wayangplan.ExecutionOperator
copy, createLoadProfileEstimator, createOutputChannelInstances, getLimitBaseKey, getLoadProfileEstimatorConfigurationKey, getOriginal, getOutputChannelDescriptor, isFiltered
-
Methods inherited from interface org.apache.wayang.java.operators.JavaExecutionOperator
getPlatform
-
Methods inherited from interface org.apache.wayang.core.plan.wayangplan.Operator
addBroadcastInput, addTargetPlatform, broadcastTo, broadcastTo, collectMappedInputSlots, collectMappedOutputSlots, connectTo, connectTo, getAllInputs, getAllOutputs, getCardinalityPusher, getContainer, getEffectiveOccupant, getEffectiveOccupant, getEpoch, getEstimationContextProperties, getForwards, getInnermostLoop, getInput, getInput, getLoopStack, getName, getNumBroadcastInputs, getNumInputs, getNumOutputs, getNumRegularInputs, getOuterInputSlot, getOutermostInputSlot, getOutermostOutputSlots, getOutput, getOutput, getParent, getTargetPlatforms, isAlternative, isElementary, isExecutionOperator, isFeedbackInput, isFeedforwardOutput, isLoopHead, isLoopSubplan, isOwnerOf, isReading, isSink, isSource, isSubplan, isSupportingBroadcastInputs, isUnconnected, propagateInputCardinality, propagateOutputCardinality, propagateOutputCardinality, setContainer, setEpoch, setInput, setName, setOutput
-
-
-
-
Constructor Detail
-
GenericSqlToStreamOperator
public GenericSqlToStreamOperator(GenericJdbcPlatform jdbcPlatform)
Creates a new instance.- Parameters:
jdbcPlatform- from which the SQL data comes
-
GenericSqlToStreamOperator
public GenericSqlToStreamOperator(GenericJdbcPlatform jdbcPlatform, DataSetType<Record> dataSetType)
Creates a new instance.- Parameters:
jdbcPlatform- from which the SQL data comesdataSetType- type of theRecords being transformed; seeRecordType
-
GenericSqlToStreamOperator
protected GenericSqlToStreamOperator(GenericSqlToStreamOperator that)
-
-
Method Detail
-
evaluate
public Tuple<java.util.Collection<ExecutionLineageNode>,java.util.Collection<ChannelInstance>> evaluate(ChannelInstance[] inputs, ChannelInstance[] outputs, JavaExecutor executor, OptimizationContext.OperatorContext operatorContext)
Description copied from interface:JavaExecutionOperatorEvaluates this operator. Takes a set of JavaStreams according to the operator inputs and produces a set ofStreams according to the operator outputs -- unless the operator is a sink, then it triggers execution.In addition, this method should give feedback of what this instance was doing by wiring the
LazyExecutionLineageNodes of input and ouputChannelInstances and providing aCollectionof executedOptimizationContext.OperatorContexts.- Specified by:
evaluatein interfaceJavaExecutionOperator- Parameters:
inputs-ChannelInstances that satisfy the inputs of this operatoroutputs-ChannelInstances that collect the outputs of this operatorexecutor- that executes this instanceoperatorContext- optimization information for this instance- Returns:
Collections of what has been executed and produced
-
getSupportedInputChannels
public java.util.List<ChannelDescriptor> getSupportedInputChannels(int index)
Description copied from interface:ExecutionOperator- Specified by:
getSupportedInputChannelsin interfaceExecutionOperator- Parameters:
index- the index of theInputSlot- Returns:
- an
ListofChannels'Classes, ordered by their preference of use
-
getSupportedOutputChannels
public java.util.List<ChannelDescriptor> getSupportedOutputChannels(int index)
Description copied from interface:ExecutionOperatorDisplay the supportedChannels for a certainOutputSlot.- Specified by:
getSupportedOutputChannelsin interfaceExecutionOperator- Parameters:
index- the index of theOutputSlot- Returns:
- an
ListofChannels'Classes, ordered by their preference of use - See Also:
ExecutionOperator.getOutputChannelDescriptor(int)
-
getLoadProfileEstimatorConfigurationKeys
public java.util.Collection<java.lang.String> getLoadProfileEstimatorConfigurationKeys()
Description copied from interface:ExecutionOperatorProvide theConfigurationkeys for theLoadProfileEstimatorspecification of this instance.- Specified by:
getLoadProfileEstimatorConfigurationKeysin interfaceExecutionOperator- Returns:
- the
Configurationkeys
-
toJson
public WayangJsonObj toJson()
Description copied from interface:JsonSerializableConvert this instance to aWayangJsonObj.- Specified by:
toJsonin interfaceJsonSerializable- Returns:
- the
WayangJsonObj
-
fromJson
public static GenericSqlToStreamOperator fromJson(WayangJsonObj wayangJsonObj)
-
-