本文整理匯總了Java中com.espertech.esper.epl.spec.OutputLimitSpec.getDisplayLimit方法的典型用法代碼示例。如果您正苦於以下問題:Java OutputLimitSpec.getDisplayLimit方法的具體用法?Java OutputLimitSpec.getDisplayLimit怎麽用?Java OutputLimitSpec.getDisplayLimit使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類com.espertech.esper.epl.spec.OutputLimitSpec
的用法示例。
在下文中一共展示了OutputLimitSpec.getDisplayLimit方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: ResultSetProcessorRowPerGroupFactory
import com.espertech.esper.epl.spec.OutputLimitSpec; //導入方法依賴的package包/類
/**
* Ctor.
* @param selectExprProcessor - for processing the select expression and generting the final output rows
* @param groupKeyNodes - list of group-by expression nodes needed for building the group-by keys
* @param optionalHavingNode - expression node representing validated HAVING clause, or null if none given.
* Aggregation functions in the having node must have been pointed to the AggregationService for evaluation.
* @param isSelectRStream - true if remove stream events should be generated
* @param isUnidirectional - true if unidirectional join
*/
public ResultSetProcessorRowPerGroupFactory(SelectExprProcessor selectExprProcessor,
ExprEvaluator[] groupKeyNodes,
ExprEvaluator optionalHavingNode,
boolean isSelectRStream,
boolean isUnidirectional,
OutputLimitSpec outputLimitSpec,
boolean isSorting,
boolean noDataWindowSingleStream)
{
this.selectExprProcessor = selectExprProcessor;
this.groupKeyNodes = groupKeyNodes;
if (groupKeyNodes.length == 1) {
this.groupKeyNode = groupKeyNodes[0];
}
else {
this.groupKeyNode = null;
}
this.optionalHavingNode = optionalHavingNode;
this.isSorting = isSorting;
this.isSelectRStream = isSelectRStream;
this.isUnidirectional = isUnidirectional;
this.outputLimitSpec = outputLimitSpec;
this.noDataWindowSingleSnapshot = (outputLimitSpec != null && outputLimitSpec.getDisplayLimit() == OutputLimitLimitType.SNAPSHOT && noDataWindowSingleStream);
}
示例2: ResultSetProcessorRowPerGroupForge
import com.espertech.esper.epl.spec.OutputLimitSpec; //導入方法依賴的package包/類
public ResultSetProcessorRowPerGroupForge(EventType resultEventType,
SelectExprProcessorForge selectExprProcessorForge,
ExprNode[] groupKeyNodeExpressions,
ExprForge optionalHavingNode,
boolean isSelectRStream,
boolean isUnidirectional,
OutputLimitSpec outputLimitSpec,
boolean isSorting,
boolean noDataWindowSingleStream,
boolean isHistoricalOnly,
boolean iterateUnbounded,
ResultSetProcessorHelperFactory resultSetProcessorHelperFactory,
ResultSetProcessorOutputConditionType outputConditionType,
int numStreams,
OutputConditionPolledFactory optionalOutputFirstConditionFactory) {
this.resultEventType = resultEventType;
this.groupKeyNodeExpressions = groupKeyNodeExpressions;
this.selectExprProcessorForge = selectExprProcessorForge;
this.optionalHavingNode = optionalHavingNode;
this.isSorting = isSorting;
this.isSelectRStream = isSelectRStream;
this.isUnidirectional = isUnidirectional;
this.outputLimitSpec = outputLimitSpec;
boolean noDataWindowSingleSnapshot = iterateUnbounded || (outputLimitSpec != null && outputLimitSpec.getDisplayLimit() == OutputLimitLimitType.SNAPSHOT && noDataWindowSingleStream);
this.unboundedProcessor = noDataWindowSingleSnapshot && !isHistoricalOnly;
this.isHistoricalOnly = isHistoricalOnly;
this.resultSetProcessorHelperFactory = resultSetProcessorHelperFactory;
this.outputConditionType = outputConditionType;
this.numStreams = numStreams;
this.optionalOutputFirstConditionFactory = optionalOutputFirstConditionFactory;
this.groupKeyTypes = ExprNodeUtilityCore.getExprResultTypes(groupKeyNodeExpressions);
}
示例3: ResultSetProcessorRowPerGroupRollupForge
import com.espertech.esper.epl.spec.OutputLimitSpec; //導入方法依賴的package包/類
public ResultSetProcessorRowPerGroupRollupForge(EventType resultEventType,
GroupByRollupPerLevelForge perLevelForges,
ExprNode[] groupKeyNodeExpressions,
boolean isSelectRStream,
boolean isUnidirectional,
OutputLimitSpec outputLimitSpec,
boolean isSorting,
boolean noDataWindowSingleStream,
AggregationGroupByRollupDesc groupByRollupDesc,
boolean isJoin,
boolean isHistoricalOnly,
boolean iterateUnbounded,
OutputConditionPolledFactory optionalOutputFirstConditionFactory,
ResultSetProcessorHelperFactory resultSetProcessorHelperFactory,
ResultSetProcessorOutputConditionType outputConditionType,
int numStreams) {
this.resultEventType = resultEventType;
this.groupKeyNodeExpressions = groupKeyNodeExpressions;
this.perLevelForges = perLevelForges;
this.isSorting = isSorting;
this.isSelectRStream = isSelectRStream;
this.isUnidirectional = isUnidirectional;
this.outputLimitSpec = outputLimitSpec;
boolean noDataWindowSingleSnapshot = iterateUnbounded || (outputLimitSpec != null && outputLimitSpec.getDisplayLimit() == OutputLimitLimitType.SNAPSHOT && noDataWindowSingleStream);
this.unbounded = noDataWindowSingleSnapshot && !isHistoricalOnly;
this.groupByRollupDesc = groupByRollupDesc;
this.isJoin = isJoin;
this.isHistoricalOnly = isHistoricalOnly;
this.optionalOutputFirstConditionFactory = optionalOutputFirstConditionFactory;
this.resultSetProcessorHelperFactory = resultSetProcessorHelperFactory;
this.outputConditionType = outputConditionType;
this.numStreams = numStreams;
this.groupKeyTypes = ExprNodeUtilityCore.getExprResultTypes(groupKeyNodeExpressions);
}
示例4: createCondition
import com.espertech.esper.epl.spec.OutputLimitSpec; //導入方法依賴的package包/類
public static OutputConditionFactory createCondition(OutputLimitSpec outputLimitSpec,
StatementContext statementContext,
boolean isGrouped,
boolean isWithHavingClause,
boolean isStartConditionOnCreation,
ResultSetProcessorHelperFactory resultSetProcessorHelperFactory)
throws ExprValidationException {
if (outputLimitSpec == null) {
return new OutputConditionNullFactory();
}
// Check if a variable is present
VariableMetaData variableMetaData = null;
if (outputLimitSpec.getVariableName() != null) {
variableMetaData = statementContext.getVariableService().getVariableMetaData(outputLimitSpec.getVariableName());
if (variableMetaData == null) {
throw new ExprValidationException("Variable named '" + outputLimitSpec.getVariableName() + "' has not been declared");
}
String message = VariableServiceUtil.checkVariableContextName(statementContext.getContextDescriptor(), variableMetaData);
if (message != null) {
throw new ExprValidationException(message);
}
}
if (outputLimitSpec.getDisplayLimit() == OutputLimitLimitType.FIRST && isGrouped) {
return new OutputConditionNullFactory();
}
if (outputLimitSpec.getRateType() == OutputLimitRateType.CRONTAB) {
return resultSetProcessorHelperFactory.makeOutputConditionCrontab(outputLimitSpec.getCrontabAtSchedule(), statementContext, isStartConditionOnCreation);
} else if (outputLimitSpec.getRateType() == OutputLimitRateType.WHEN_EXPRESSION) {
return resultSetProcessorHelperFactory.makeOutputConditionExpression(outputLimitSpec.getWhenExpressionNode(), outputLimitSpec.getThenExpressions(), statementContext, outputLimitSpec.getAndAfterTerminateExpr(), outputLimitSpec.getAndAfterTerminateThenExpressions(), isStartConditionOnCreation);
} else if (outputLimitSpec.getRateType() == OutputLimitRateType.EVENTS) {
if (log.isDebugEnabled()) {
log.debug(".createCondition creating OutputConditionCount with event rate " + outputLimitSpec);
}
if ((variableMetaData != null) && (!JavaClassHelper.isNumericNonFP(variableMetaData.getType()))) {
throw new IllegalArgumentException("Variable named '" + outputLimitSpec.getVariableName() + "' must be type integer, long or short");
}
int rate = -1;
if (outputLimitSpec.getRate() != null) {
rate = outputLimitSpec.getRate().intValue();
}
return resultSetProcessorHelperFactory.makeOutputConditionCount(rate, variableMetaData, statementContext);
} else if (outputLimitSpec.getRateType() == OutputLimitRateType.TERM) {
if (outputLimitSpec.getAndAfterTerminateExpr() == null && (outputLimitSpec.getAndAfterTerminateThenExpressions() == null || outputLimitSpec.getAndAfterTerminateThenExpressions().isEmpty())) {
return new OutputConditionTermFactory();
} else {
return resultSetProcessorHelperFactory.makeOutputConditionExpression(new ExprConstantNodeImpl(false), Collections.<OnTriggerSetAssignment>emptyList(), statementContext, outputLimitSpec.getAndAfterTerminateExpr(), outputLimitSpec.getAndAfterTerminateThenExpressions(), isStartConditionOnCreation);
}
} else {
if (log.isDebugEnabled()) {
log.debug(".createCondition creating OutputConditionTime with interval length " + outputLimitSpec.getRate());
}
if ((variableMetaData != null) && (!JavaClassHelper.isNumeric(variableMetaData.getType()))) {
throw new IllegalArgumentException("Variable named '" + outputLimitSpec.getVariableName() + "' must be of numeric type");
}
return resultSetProcessorHelperFactory.makeOutputConditionTime(outputLimitSpec.getTimePeriodExpr(), isStartConditionOnCreation);
}
}