com.espertech.esper.epl.join.exec.base.FullTableScanLookupStrategy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of esper Show documentation
Show all versions of esper Show documentation
Complex event processing and event series analysis component
/*
***************************************************************************************
* Copyright (C) 2006 EsperTech, Inc. All rights reserved. *
* http://www.espertech.com/esper *
* http://www.espertech.com *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the GPL license *
* a copy of which has been included with this distribution in the license.txt file. *
***************************************************************************************
*/
package com.espertech.esper.epl.join.exec.base;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.epl.expression.core.ExprEvaluatorContext;
import com.espertech.esper.epl.join.rep.Cursor;
import com.espertech.esper.epl.join.table.UnindexedEventTable;
import com.espertech.esper.epl.lookup.LookupStrategyDesc;
import com.espertech.esper.epl.lookup.LookupStrategyType;
import com.espertech.esper.metrics.instrumentation.InstrumentationHelper;
import java.util.Set;
/**
* Lookup on an unindexed table returning the full table as matching events.
*/
public class FullTableScanLookupStrategy implements JoinExecTableLookupStrategy {
private UnindexedEventTable eventIndex;
/**
* Ctor.
*
* @param eventIndex - table to use
*/
public FullTableScanLookupStrategy(UnindexedEventTable eventIndex) {
this.eventIndex = eventIndex;
}
public Set lookup(EventBean theEvent, Cursor cursor, ExprEvaluatorContext exprEvaluatorContext) {
if (InstrumentationHelper.ENABLED) {
InstrumentationHelper.get().qIndexJoinLookup(this, eventIndex);
}
Set result = eventIndex.getEventSet();
if (result.isEmpty()) {
if (InstrumentationHelper.ENABLED) {
InstrumentationHelper.get().aIndexJoinLookup(null, null);
}
return null;
}
if (InstrumentationHelper.ENABLED) {
InstrumentationHelper.get().aIndexJoinLookup(result, null);
}
return result;
}
/**
* Returns the associated table.
*
* @return table for lookup.
*/
public UnindexedEventTable getEventIndex() {
return eventIndex;
}
public LookupStrategyDesc getStrategyDesc() {
return new LookupStrategyDesc(LookupStrategyType.FULLTABLESCAN, null);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy