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


Java OuterJoinDesc類代碼示例

本文整理匯總了Java中com.espertech.esper.epl.spec.OuterJoinDesc的典型用法代碼示例。如果您正苦於以下問題:Java OuterJoinDesc類的具體用法?Java OuterJoinDesc怎麽用?Java OuterJoinDesc使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


OuterJoinDesc類屬於com.espertech.esper.epl.spec包,在下文中一共展示了OuterJoinDesc類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: analyze

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
/**
 * Analyzes the outer join descriptor list to build a query graph model.
 *
 * @param outerJoinDescList - list of outer join descriptors
 * @param queryGraph        - model containing relationships between streams that is written into
 * @return queryGraph object
 */
public static QueryGraph analyze(OuterJoinDesc[] outerJoinDescList, QueryGraph queryGraph) {
    for (OuterJoinDesc outerJoinDesc : outerJoinDescList) {
        // add optional on-expressions
        if (outerJoinDesc.getOptLeftNode() != null) {
            ExprIdentNode identNodeLeft = outerJoinDesc.getOptLeftNode();
            ExprIdentNode identNodeRight = outerJoinDesc.getOptRightNode();

            add(queryGraph, identNodeLeft, identNodeRight);

            if (outerJoinDesc.getAdditionalLeftNodes() != null) {
                for (int i = 0; i < outerJoinDesc.getAdditionalLeftNodes().length; i++) {
                    add(queryGraph, outerJoinDesc.getAdditionalLeftNodes()[i], outerJoinDesc.getAdditionalRightNodes()[i]);
                }
            }
        }
    }

    return queryGraph;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:27,代碼來源:OuterJoinAnalyzer.java

示例2: testAnalyze

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public void testAnalyze() throws Exception {
    OuterJoinDesc[] descList = new OuterJoinDesc[2];
    descList[0] = SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s0", "intBoxed", "s1", OuterJoinType.LEFT);
    descList[1] = SupportOuterJoinDescFactory.makeDesc("simpleProperty", "s2", "theString", "s1", OuterJoinType.LEFT);
    // simpleProperty in s2

    QueryGraph graph = new QueryGraph(3, null, false);
    OuterJoinAnalyzer.analyze(descList, graph);
    assertEquals(3, graph.getNumStreams());

    assertTrue(graph.isNavigableAtAll(0, 1));
    assertEquals(1, QueryGraphTestUtil.getStrictKeyProperties(graph, 0, 1).length);
    assertEquals("intPrimitive", QueryGraphTestUtil.getStrictKeyProperties(graph, 0, 1)[0]);
    assertEquals(1, QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 0).length);
    assertEquals("intBoxed", QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 0)[0]);

    assertTrue(graph.isNavigableAtAll(1, 2));
    assertEquals("theString", QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 2)[0]);
    assertEquals("simpleProperty", QueryGraphTestUtil.getStrictKeyProperties(graph, 2, 1)[0]);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:21,代碼來源:TestOuterJoinAnalyzer.java

示例3: testGetPlan

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public void testGetPlan() throws Exception {
    OuterJoinDesc[] descList = new OuterJoinDesc[]{
            SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s0", "intBoxed", "s1", OuterJoinType.LEFT)
    };

    QueryGraph queryGraph = new QueryGraph(2, null, false);
    EngineImportService engineImportService = SupportEngineImportServiceFactory.make();
    QueryPlan plan = QueryPlanBuilder.getPlan(typesPerStream, new OuterJoinDesc[0], queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null, engineImportService, false);
    assertPlan(plan);

    plan = QueryPlanBuilder.getPlan(typesPerStream, descList, queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null, engineImportService, false);
    assertPlan(plan);

    FilterExprAnalyzer.analyze(SupportExprNodeFactory.makeEqualsNode(), queryGraph, false);
    plan = QueryPlanBuilder.getPlan(typesPerStream, descList, queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null, engineImportService, false);
    assertPlan(plan);

    plan = QueryPlanBuilder.getPlan(typesPerStream, new OuterJoinDesc[0], queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null, engineImportService, false);
    assertPlan(plan);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:21,代碼來源:TestQueryPlanBuilder.java

示例4: getFilterExpressionInclOnClause

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
private ExprNode getFilterExpressionInclOnClause(ExprNode optionalFilterNode, List<OuterJoinDesc> outerJoinDescList)
{
    if (optionalFilterNode == null) {   // no need to add as query planning is fully based on on-clause
        return null;
    }
    if (outerJoinDescList.isEmpty()) {  // not an outer-join syntax
        return optionalFilterNode;
    }
    if (!OuterJoinDesc.consistsOfAllInnerJoins(outerJoinDescList)) {    // all-inner joins
        return optionalFilterNode;
    }
    ExprAndNode andNode = new ExprAndNodeImpl();
    andNode.addChildNode(optionalFilterNode);
    for (OuterJoinDesc outerJoinDesc : outerJoinDescList) {
        andNode.addChildNode(outerJoinDesc.makeExprNode(null));
    }
    try {
        andNode.validate(null);
    }
    catch (ExprValidationException ex) {
        throw new RuntimeException("Unexpected exception validating expression: " + ex.getMessage(), ex);
    }
    return andNode;
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:25,代碼來源:JoinSetComposerPrototypeImpl.java

示例5: testAnalyze

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public void testAnalyze() throws Exception
{
    List<OuterJoinDesc> descList = new LinkedList<OuterJoinDesc>();
    descList.add(SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s0", "intBoxed", "s1", OuterJoinType.LEFT));
    descList.add(SupportOuterJoinDescFactory.makeDesc("simpleProperty", "s2", "theString", "s1", OuterJoinType.LEFT));
    // simpleProperty in s2

    QueryGraph graph = new QueryGraph(3);
    OuterJoinAnalyzer.analyze(descList, graph);
    assertEquals(3, graph.getNumStreams());

    assertTrue(graph.isNavigableAtAll(0, 1));
    assertEquals(1, QueryGraphTestUtil.getStrictKeyProperties(graph, 0, 1).length);
    assertEquals("intPrimitive", QueryGraphTestUtil.getStrictKeyProperties(graph, 0, 1)[0]);
    assertEquals(1, QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 0).length);
    assertEquals("intBoxed", QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 0)[0]);

    assertTrue(graph.isNavigableAtAll(1, 2));
    assertEquals("theString", QueryGraphTestUtil.getStrictKeyProperties(graph, 1, 2)[0]);
    assertEquals("simpleProperty", QueryGraphTestUtil.getStrictKeyProperties(graph, 2, 1)[0]);
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:22,代碼來源:TestOuterJoinAnalyzer.java

示例6: testGetPlan

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public void testGetPlan() throws Exception
{
    List<OuterJoinDesc> descList = new LinkedList<OuterJoinDesc>();
    OuterJoinDesc joinDesc = SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s0", "intBoxed", "s1", OuterJoinType.LEFT);
    descList.add(joinDesc);

    QueryGraph queryGraph = new QueryGraph(2);
    QueryPlan plan = QueryPlanBuilder.getPlan(typesPerStream, new LinkedList<OuterJoinDesc>(), queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null);
    assertPlan(plan);

    plan = QueryPlanBuilder.getPlan(typesPerStream, descList, queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null);
    assertPlan(plan);

    FilterExprAnalyzer.analyze(SupportExprNodeFactory.makeEqualsNode(), queryGraph, false);
    plan = QueryPlanBuilder.getPlan(typesPerStream, descList, queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null);
    assertPlan(plan);

    plan = QueryPlanBuilder.getPlan(typesPerStream, new LinkedList<OuterJoinDesc>(), queryGraph, null, new HistoricalViewableDesc(5), dependencyGraph, null, new StreamJoinAnalysisResult(2), true, null, null);
    assertPlan(plan);
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:21,代碼來源:TestQueryPlanBuilder.java

示例7: JoinSetComposerPrototypeHistorical2StreamImpl

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public JoinSetComposerPrototypeHistorical2StreamImpl(ExprEvaluator optionalFilterEval, EventType[] streamTypes, ExprEvaluatorContext exprEvaluatorContext, int polledViewNum, int streamViewNum, boolean outerJoin, ExprEvaluator outerJoinEqualsEval, Pair<HistoricalIndexLookupStrategy, PollResultIndexingStrategy> indexStrategies, boolean allHistoricalNoSubordinate, OuterJoinDesc[] outerJoinDescList, boolean allowIndexInit) {
    this.optionalFilterEval = optionalFilterEval;
    this.streamTypes = streamTypes;
    this.exprEvaluatorContext = exprEvaluatorContext;
    this.polledViewNum = polledViewNum;
    this.streamViewNum = streamViewNum;
    isOuterJoin = outerJoin;
    this.outerJoinEqualsEval = outerJoinEqualsEval;
    this.indexStrategies = indexStrategies;
    isAllHistoricalNoSubordinate = allHistoricalNoSubordinate;
    this.outerJoinDescList = outerJoinDescList;
    this.allowIndexInit = allowIndexInit;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:14,代碼來源:JoinSetComposerPrototypeHistorical2StreamImpl.java

示例8: getFilterExpressionInclOnClause

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
private ExprNode getFilterExpressionInclOnClause(ExprNode optionalFilterNode, OuterJoinDesc[] outerJoinDescList) {
    if (optionalFilterNode == null) {   // no need to add as query planning is fully based on on-clause
        return null;
    }
    if (outerJoinDescList.length == 0) {  // not an outer-join syntax
        return optionalFilterNode;
    }
    if (!OuterJoinDesc.consistsOfAllInnerJoins(outerJoinDescList)) {    // all-inner joins
        return optionalFilterNode;
    }

    boolean hasOnClauses = OuterJoinDesc.hasOnClauses(outerJoinDescList);
    if (!hasOnClauses) {
        return optionalFilterNode;
    }

    List<ExprNode> expressions = new ArrayList<>();
    expressions.add(optionalFilterNode);

    for (OuterJoinDesc outerJoinDesc : outerJoinDescList) {
        if (outerJoinDesc.getOptLeftNode() != null) {
            expressions.add(outerJoinDesc.makeExprNode(null));
        }
    }

    ExprAndNode andNode = ExprNodeUtilityRich.connectExpressionsByLogicalAnd(expressions);
    try {
        andNode.validate(null);
    } catch (ExprValidationException ex) {
        throw new RuntimeException("Unexpected exception validating expression: " + ex.getMessage(), ex);
    }
    return andNode;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:34,代碼來源:JoinSetComposerPrototypeImpl.java

示例9: optionalStreamsIfAny

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public static boolean optionalStreamsIfAny(OuterJoinDesc[] outerJoinDescList) {
    if (outerJoinDescList == null || outerJoinDescList.length == 0) {
        return false;
    }
    for (OuterJoinDesc outerJoinDesc : outerJoinDescList) {
        if (outerJoinDesc.getOuterJoinType() != OuterJoinType.INNER) {
            return true;
        }
    }
    return false;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:12,代碼來源:OuterJoinAnalyzer.java

示例10: graphInnerJoins

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public static InnerJoinGraph graphInnerJoins(int numStreams, OuterJoinDesc[] outerJoinDescList) {
    if ((outerJoinDescList.length + 1) != numStreams) {
        throw new IllegalArgumentException("Number of outer join descriptors and number of streams not matching up");
    }

    Set<InterchangeablePair<Integer, Integer>> graph = new HashSet<InterchangeablePair<Integer, Integer>>();

    boolean allInnerJoin = true;
    for (int i = 0; i < outerJoinDescList.length; i++) {
        OuterJoinDesc desc = outerJoinDescList[i];
        int streamMax = i + 1;       // the outer join must references streams less then streamMax

        // Check outer join on-expression, if provided
        if (desc.getOptLeftNode() != null) {
            int streamOne = desc.getOptLeftNode().getStreamId();
            int streamTwo = desc.getOptRightNode().getStreamId();

            if ((streamOne > streamMax) || (streamTwo > streamMax) ||
                    (streamOne == streamTwo)) {
                throw new IllegalArgumentException("Outer join descriptors reference future streams, or same streams");
            }

            if (desc.getOuterJoinType() == OuterJoinType.INNER) {
                graph.add(new InterchangeablePair<Integer, Integer>(streamOne, streamTwo));
            }
        }

        if (desc.getOuterJoinType() != OuterJoinType.INNER) {
            allInnerJoin = false;
        }
    }

    if (allInnerJoin) {
        return new InnerJoinGraph(numStreams, true);
    }
    return new InnerJoinGraph(numStreams, graph);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:38,代碼來源:InnerJoinGraph.java

示例11: makeDesc

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public static OuterJoinDesc makeDesc(String propOne, String streamOne, String propTwo, String streamTwo, OuterJoinType type) throws Exception {
    ExprIdentNode identNodeOne = new ExprIdentNodeImpl(propOne, streamOne);
    ExprIdentNode identNodeTwo = new ExprIdentNodeImpl(propTwo, streamTwo);

    ExprValidationContext context = SupportExprValidationContextFactory.make(new SupportStreamTypeSvc3Stream());
    identNodeOne.validate(context);
    identNodeTwo.validate(context);
    OuterJoinDesc desc = new OuterJoinDesc(type, identNodeOne, identNodeTwo, null, null);

    return desc;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:12,代碼來源:SupportOuterJoinDescFactory.java

示例12: testGraphOuterJoins

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public void testGraphOuterJoins() throws Exception {
    OuterJoinDesc[] descList = new OuterJoinDesc[2];
    descList[0] = SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s0", "intBoxed", "s1", OuterJoinType.RIGHT);
    descList[1] = SupportOuterJoinDescFactory.makeDesc("simpleProperty", "s2", "theString", "s1", OuterJoinType.FULL);

    OuterInnerDirectionalGraph graph = NStreamOuterQueryPlanBuilder.graphOuterJoins(3, descList);

    // assert the inner and outer streams for each stream
    assertInners(new int[][]{null, {0, 2}, {1}}, graph);
    assertOuters(new int[][]{{1}, {2}, {1}}, graph);

    descList[0] = SupportOuterJoinDescFactory.makeDesc("intPrimitive", "s1", "intBoxed", "s0", OuterJoinType.LEFT);
    descList[1] = SupportOuterJoinDescFactory.makeDesc("simpleProperty", "s2", "theString", "s1", OuterJoinType.RIGHT);

    graph = NStreamOuterQueryPlanBuilder.graphOuterJoins(3, descList);

    // assert the inner and outer streams for each stream
    assertInners(new int[][]{{1}, null, {1}}, graph);
    assertOuters(new int[][]{null, {0, 2}, null}, graph);

    try {
        NStreamOuterQueryPlanBuilder.graphOuterJoins(3, new OuterJoinDesc[0]);
        fail();
    } catch (IllegalArgumentException ex) {
        // expected
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:28,代碼來源:TestNStreamOuterQueryPlanBuilder.java

示例13: JoinSetComposerPrototypeHistorical2StreamImpl

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public JoinSetComposerPrototypeHistorical2StreamImpl(ExprNode optionalFilterNode, EventType[] streamTypes, ExprEvaluatorContext exprEvaluatorContext, int polledViewNum, int streamViewNum, boolean outerJoin, ExprNode outerJoinEqualsNode, Pair<HistoricalIndexLookupStrategy, PollResultIndexingStrategy> indexStrategies, boolean allHistoricalNoSubordinate, List<OuterJoinDesc> outerJoinDescList) {
    this.optionalFilterNode = optionalFilterNode;
    this.streamTypes = streamTypes;
    this.exprEvaluatorContext = exprEvaluatorContext;
    this.polledViewNum = polledViewNum;
    this.streamViewNum = streamViewNum;
    isOuterJoin = outerJoin;
    this.outerJoinEqualsNode = outerJoinEqualsNode;
    this.indexStrategies = indexStrategies;
    isAllHistoricalNoSubordinate = allHistoricalNoSubordinate;
    this.outerJoinDescList = outerJoinDescList;
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:13,代碼來源:JoinSetComposerPrototypeHistorical2StreamImpl.java

示例14: JoinSetComposerPrototypeImpl

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
public JoinSetComposerPrototypeImpl(String statementName,
                                    String statementId,
                                    List<OuterJoinDesc> outerJoinDescList,
                                    ExprNode optionalFilterNode,
                                    EventType[] streamTypes,
                                    String[] streamNames,
                                    StreamJoinAnalysisResult streamJoinAnalysisResult,
                                    Annotation[] annotations,
                                    HistoricalViewableDesc historicalViewableDesc,
                                    ExprEvaluatorContext exprEvaluatorContext,
                                    QueryPlanIndex[] indexSpecs,
                                    QueryPlan queryPlan,
                                    HistoricalStreamIndexList[] historicalStreamIndexLists,
                                    boolean joinRemoveStream,
                                    boolean isOuterJoins) {
    this.statementName = statementName;
    this.statementId = statementId;
    this.outerJoinDescList = outerJoinDescList;
    this.optionalFilterNode = optionalFilterNode;
    this.streamTypes = streamTypes;
    this.streamNames = streamNames;
    this.streamJoinAnalysisResult = streamJoinAnalysisResult;
    this.annotations = annotations;
    this.historicalViewableDesc = historicalViewableDesc;
    this.exprEvaluatorContext = exprEvaluatorContext;
    this.indexSpecs = indexSpecs;
    this.queryPlan = queryPlan;
    this.historicalStreamIndexLists = historicalStreamIndexLists;
    this.joinRemoveStream = joinRemoveStream;
    this.isOuterJoins = isOuterJoins;
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:32,代碼來源:JoinSetComposerPrototypeImpl.java

示例15: analyze

import com.espertech.esper.epl.spec.OuterJoinDesc; //導入依賴的package包/類
/**
 * Analyzes the outer join descriptor list to build a query graph model.
 * @param outerJoinDescList - list of outer join descriptors
 * @param queryGraph - model containing relationships between streams that is written into
 * @return queryGraph object
 */
public static QueryGraph analyze(List<OuterJoinDesc> outerJoinDescList, QueryGraph queryGraph)
{
    for (OuterJoinDesc outerJoinDesc : outerJoinDescList)
    {
        // add optional on-expressions
        if (outerJoinDesc.getOptLeftNode() != null) {
            ExprIdentNode identNodeLeft = outerJoinDesc.getOptLeftNode();
            ExprIdentNode identNodeRight = outerJoinDesc.getOptRightNode();

            add(queryGraph, identNodeLeft, identNodeRight);

            if (outerJoinDesc.getAdditionalLeftNodes() != null)
            {
                for (int i = 0; i < outerJoinDesc.getAdditionalLeftNodes().length; i++)
                {
                    add(queryGraph, outerJoinDesc.getAdditionalLeftNodes()[i], outerJoinDesc.getAdditionalRightNodes()[i]);
                }
            }
        }
        else {

        }
    }

    return queryGraph;
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:33,代碼來源:OuterJoinAnalyzer.java


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