public abstract class ExprSubselectNode extends ExprNodeBase implements ExprEvaluator, ExprEnumerationForge, ExprEnumerationEval, ExprTypableReturnForge, ExprTypableReturnEval, ExprForge
Modifier and Type | Class and Description |
---|---|
static class |
ExprSubselectNode.SubqueryAggregationType |
Modifier and Type | Field and Description |
---|---|
static ExprSubselectNode[] |
EMPTY_SUBSELECT_ARRAY |
protected ExprEvaluator |
filterExpr
The validate filter expression.
|
protected ExprEvaluator |
havingExpr
The validated having expression.
|
protected EventType |
rawEventType
The event type generated for wildcard selects.
|
protected String[] |
selectAsNames |
protected ExprNode[] |
selectClause
The validated select clause.
|
protected ExprEvaluator[] |
selectClauseEvaluator |
protected String |
statementName |
protected AggregationService |
subselectAggregationService |
protected int |
subselectNumber |
Constructor and Description |
---|
ExprSubselectNode(StatementSpecRaw statementSpec)
Ctor.
|
Modifier and Type | Method and Description |
---|---|
boolean |
equalsNode(ExprNode node,
boolean ignoreStreamPrefix)
Return true if a expression node semantically equals the current node, or false if not.
|
abstract Object |
evaluate(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext)
Evaluate the lookup expression returning an evaluation result object.
|
Object |
evaluate(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext exprEvaluatorContext)
Evaluate event tuple and return result.
|
CodegenExpression |
evaluateCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
abstract Collection<EventBean> |
evaluateGetCollEvents(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext) |
abstract Collection |
evaluateGetCollScalar(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext) |
abstract EventBean |
evaluateGetEventBean(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext) |
EventBean |
evaluateGetEventBean(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext context) |
CodegenExpression |
evaluateGetEventBeanCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
Collection<EventBean> |
evaluateGetROCollectionEvents(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext exprEvaluatorContext) |
CodegenExpression |
evaluateGetROCollectionEventsCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
Collection |
evaluateGetROCollectionScalar(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext exprEvaluatorContext) |
CodegenExpression |
evaluateGetROCollectionScalarCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
abstract Object[][] |
evaluateTypableMulti(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext) |
Object[][] |
evaluateTypableMulti(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext context) |
CodegenExpression |
evaluateTypableMultiCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
abstract Object[] |
evaluateTypableSingle(EventBean[] eventsPerStream,
boolean isNewData,
Collection<EventBean> matchingEvents,
ExprEvaluatorContext exprEvaluatorContext) |
Object[] |
evaluateTypableSingle(EventBean[] eventsPerStream,
boolean isNewData,
ExprEvaluatorContext context) |
CodegenExpression |
evaluateTypableSingleCodegen(CodegenParamSetExprPremade params,
CodegenContext context) |
ExprForgeComplexityEnum |
getComplexity() |
ExprEvaluator |
getExprEvaluator() |
ExprEnumerationEval |
getExprEvaluatorEnumeration() |
ExprEvaluator |
getFilterExpr()
Returns filter expr or null if none.
|
StreamTypeService |
getFilterSubqueryStreamTypes()
Return stream types.
|
ExprForge |
getForge() |
ExprNodeRenderable |
getForgeRenderable() |
ExprEvaluator |
getHavingExpr() |
ExprPrecedenceEnum |
getPrecedence()
Returns precedence.
|
EventType |
getRawEventType()
Returns the event type.
|
LinkedHashMap<String,Object> |
getRowProperties()
Return null to indicate no row-type result available,
or a map of property names and types to indicate a row-type result is available.
|
ExprNode[] |
getSelectClause()
Returns the select clause or null if none.
|
StatementSpecCompiled |
getStatementSpecCompiled()
Returns the compiled statement spec.
|
StatementSpecRaw |
getStatementSpecRaw()
Returns the uncompiled statement spec.
|
AggregationService |
getSubselectAggregationService() |
ExprSubselectNode.SubqueryAggregationType |
getSubselectAggregationType() |
int |
getSubselectNumber() |
ExprTypableReturnEval |
getTypableReturnEvaluator() |
abstract boolean |
isAllowMultiColumnSelect() |
boolean |
isConstantResult()
Returns true if the expression node's evaluation value doesn't depend on any events data,
as must be determined at validation time, which is bottom-up and therefore
reliably allows each node to determine constant value.
|
boolean |
isFilterStreamSubselect() |
Boolean |
isMultirow()
Return true for multi-row return, return false for return of single row only
|
void |
setFilterExpr(ExprEvaluator filterExpr)
Sets the validated filter expression, or null if there is none.
|
void |
setFilterStreamSubselect(boolean filterStreamSubselect) |
void |
setFilterSubqueryStreamTypes(StreamTypeService filterSubqueryStreamTypes)
Set stream types.
|
void |
setHavingExpr(ExprEvaluator havingExpr) |
void |
setRawEventType(EventType rawEventType)
Sets the event type generated for wildcard selects.
|
void |
setSelectAsNames(String[] selectAsNames)
Supplies the name of the select expression as-tag
|
void |
setSelectClause(ExprNode[] selectClause,
EngineImportService engineImportService,
String statementName)
Sets the validates select clause
|
void |
setStatementSpecCompiled(StatementSpecCompiled statementSpecCompiled,
int subselectNumber)
Supplies a compiled statement spec.
|
void |
setStrategy(ExprSubselectStrategy strategy)
Sets the strategy for boiling down the table of lookup events into a subset against which to run the filter.
|
void |
setSubselectAggregationService(AggregationService subselectAggregationService) |
void |
setSubselectAggregationType(ExprSubselectNode.SubqueryAggregationType subselectAggregationType) |
static ExprSubselectNode[] |
toArray(List<ExprSubselectNode> subselectNodes) |
void |
toPrecedenceFreeEPL(StringWriter writer) |
abstract LinkedHashMap<String,Object> |
typableGetRowProperties() |
ExprNode |
validate(ExprValidationContext validationContext) |
abstract void |
validateSubquery(ExprValidationContext validationContext) |
accept, accept, acceptChildnodes, addChildNode, addChildNodes, addChildNodeToFront, getChildNodes, replaceUnlistedChildNode, setChildNode, setChildNodes, toEPL
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getComponentTypeCollection, getEventTypeCollection, getEventTypeSingle
getEvaluationType
public static final ExprSubselectNode[] EMPTY_SUBSELECT_ARRAY
protected ExprNode[] selectClause
protected transient ExprEvaluator[] selectClauseEvaluator
protected String[] selectAsNames
protected transient ExprEvaluator filterExpr
protected transient ExprEvaluator havingExpr
protected transient EventType rawEventType
protected String statementName
protected int subselectNumber
protected transient AggregationService subselectAggregationService
public ExprSubselectNode(StatementSpecRaw statementSpec)
statementSpec
- is the lookup statement spec from the parser, unvalidatedpublic abstract Object evaluate(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
eventsPerStream
- is the events for each stream in a joinisNewData
- is true for new data, or false for old datamatchingEvents
- is filtered results from the table of stored lookup eventsexprEvaluatorContext
- context for expression evalauationpublic abstract Collection<EventBean> evaluateGetCollEvents(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
public abstract Collection evaluateGetCollScalar(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
public abstract EventBean evaluateGetEventBean(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
public abstract boolean isAllowMultiColumnSelect()
public abstract void validateSubquery(ExprValidationContext validationContext) throws ExprValidationException
ExprValidationException
public abstract LinkedHashMap<String,Object> typableGetRowProperties() throws ExprValidationException
ExprValidationException
public abstract Object[] evaluateTypableSingle(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
public abstract Object[][] evaluateTypableMulti(EventBean[] eventsPerStream, boolean isNewData, Collection<EventBean> matchingEvents, ExprEvaluatorContext exprEvaluatorContext)
public ExprEvaluator getExprEvaluator()
getExprEvaluator
in interface ExprForge
public boolean isConstantResult()
ExprNode
isConstantResult
in interface ExprNode
public ExprNodeRenderable getForgeRenderable()
getForgeRenderable
in interface ExprEnumerationForge
getForgeRenderable
in interface ExprForge
public ExprNode validate(ExprValidationContext validationContext) throws ExprValidationException
validate
in interface ExprValidator
ExprValidationException
public void setStatementSpecCompiled(StatementSpecCompiled statementSpecCompiled, int subselectNumber)
statementSpecCompiled
- compiled validated filterssubselectNumber
- subselect assigned numberpublic StatementSpecCompiled getStatementSpecCompiled()
public void setSelectClause(ExprNode[] selectClause, EngineImportService engineImportService, String statementName)
selectClause
- is the expression representing the select clauseengineImportService
- engine import servicestatementName
- namepublic Object evaluate(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext)
ExprEvaluator
evaluate
in interface ExprEvaluator
eventsPerStream
- - event tupleisNewData
- - indicates whether we are dealing with new data (istream) or old data (rstream)exprEvaluatorContext
- context for expression evaluationpublic CodegenExpression evaluateCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateCodegen
in interface ExprForge
public ExprForgeComplexityEnum getComplexity()
getComplexity
in interface ExprForge
public Collection<EventBean> evaluateGetROCollectionEvents(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext)
evaluateGetROCollectionEvents
in interface ExprEnumerationEval
public CodegenExpression evaluateGetROCollectionEventsCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateGetROCollectionEventsCodegen
in interface ExprEnumerationForge
public Collection evaluateGetROCollectionScalar(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext)
evaluateGetROCollectionScalar
in interface ExprEnumerationEval
public CodegenExpression evaluateGetROCollectionScalarCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateGetROCollectionScalarCodegen
in interface ExprEnumerationForge
public EventBean evaluateGetEventBean(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context)
evaluateGetEventBean
in interface ExprEnumerationEval
public LinkedHashMap<String,Object> getRowProperties() throws ExprValidationException
ExprTypableReturnForge
getRowProperties
in interface ExprTypableReturnForge
ExprValidationException
- if the expression is invalidpublic Boolean isMultirow()
ExprTypableReturnForge
isMultirow
in interface ExprTypableReturnForge
public Object[] evaluateTypableSingle(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context)
evaluateTypableSingle
in interface ExprTypableReturnEval
public CodegenExpression evaluateTypableSingleCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateTypableSingleCodegen
in interface ExprTypableReturnForge
public Object[][] evaluateTypableMulti(EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context)
evaluateTypableMulti
in interface ExprTypableReturnEval
public CodegenExpression evaluateTypableMultiCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateTypableMultiCodegen
in interface ExprTypableReturnForge
public ExprEnumerationEval getExprEvaluatorEnumeration()
getExprEvaluatorEnumeration
in interface ExprEnumerationForge
public CodegenExpression evaluateGetEventBeanCodegen(CodegenParamSetExprPremade params, CodegenContext context)
evaluateGetEventBeanCodegen
in interface ExprEnumerationForge
public StatementSpecRaw getStatementSpecRaw()
public void setSelectAsNames(String[] selectAsNames)
selectAsNames
- is the as-name(s)public void setFilterExpr(ExprEvaluator filterExpr)
filterExpr
- is the filterpublic void setHavingExpr(ExprEvaluator havingExpr)
public void toPrecedenceFreeEPL(StringWriter writer)
toPrecedenceFreeEPL
in class ExprNodeBase
public ExprPrecedenceEnum getPrecedence()
ExprNode
getPrecedence
in interface ExprNode
public boolean equalsNode(ExprNode node, boolean ignoreStreamPrefix)
ExprNode
Concrete implementations should compare the type and any additional information that impact the evaluation of a node.
equalsNode
in interface ExprNode
node
- to compare toignoreStreamPrefix
- when the equals-comparison can ignore prefix of event propertiespublic void setStrategy(ExprSubselectStrategy strategy)
strategy
- is the looking strategy (full table scan or indexed)public void setRawEventType(EventType rawEventType)
rawEventType
- is the wildcard type (parent view)public ExprNode[] getSelectClause()
public ExprEvaluator getFilterExpr()
public ExprEvaluator getHavingExpr()
public EventType getRawEventType()
public StreamTypeService getFilterSubqueryStreamTypes()
public void setFilterSubqueryStreamTypes(StreamTypeService filterSubqueryStreamTypes)
filterSubqueryStreamTypes
- typespublic ExprSubselectNode.SubqueryAggregationType getSubselectAggregationType()
public void setSubselectAggregationType(ExprSubselectNode.SubqueryAggregationType subselectAggregationType)
public int getSubselectNumber()
public void setFilterStreamSubselect(boolean filterStreamSubselect)
public boolean isFilterStreamSubselect()
public static ExprSubselectNode[] toArray(List<ExprSubselectNode> subselectNodes)
public void setSubselectAggregationService(AggregationService subselectAggregationService)
public AggregationService getSubselectAggregationService()
public ExprTypableReturnEval getTypableReturnEvaluator()
getTypableReturnEvaluator
in interface ExprTypableReturnForge