當前位置: 首頁>>代碼示例>>Java>>正文


Java OutputLimitSpec.getDisplayLimit方法代碼示例

本文整理匯總了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);
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:34,代碼來源:ResultSetProcessorRowPerGroupFactory.java

示例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);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:33,代碼來源:ResultSetProcessorRowPerGroupForge.java

示例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);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:35,代碼來源:ResultSetProcessorRowPerGroupRollupForge.java

示例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);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:64,代碼來源:OutputConditionFactoryFactory.java


注:本文中的com.espertech.esper.epl.spec.OutputLimitSpec.getDisplayLimit方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。