本文整理汇总了Java中com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr类的典型用法代码示例。如果您正苦于以下问题:Java QueryPlanIndexDescOnExpr类的具体用法?Java QueryPlanIndexDescOnExpr怎么用?Java QueryPlanIndexDescOnExpr使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
QueryPlanIndexDescOnExpr类属于com.espertech.esper.epl.join.util包,在下文中一共展示了QueryPlanIndexDescOnExpr类的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: assertIndexChoice
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
private void assertIndexChoice(EPServiceProvider epService, String hint, String expectedIndexName) {
String epl = IndexBackingTableInfo.INDEX_CALLBACK_HOOK + hint +
"on SupportSpatialAABB as aabb select mpw.id as c0 from MyPointWindow as mpw " +
"where aabb.category = mpw.category and point(px, py).inside(rectangle(x, y, width, height))\n";
EPStatement stmt = epService.getEPAdministrator().createEPL(epl);
SupportUpdateListener listener = new SupportUpdateListener();
stmt.addListener(listener);
QueryPlanIndexDescOnExpr plan = SupportQueryPlanIndexHook.assertOnExprAndReset();
assertEquals(expectedIndexName, plan.getTables()[0].getIndexName());
epService.getEPRuntime().sendEvent(new SupportSpatialAABB("R1", 9, 14, 1.0001, 1.0001, "Y"));
assertEquals("P2", listener.assertOneGetNewAndReset().get("c0"));
stmt.destroy();
}
示例2: runAssertionDocSample
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
private void runAssertionDocSample(EPServiceProvider epService) {
epService.getEPAdministrator().getConfiguration().addEventType(AEvent.class);
epService.getEPAdministrator().getConfiguration().addEventType(BEvent.class);
String[] hints = new String[]{
"@hint('exclude_plan(true)')",
"@hint('exclude_plan(opname=\"equals\")')",
"@hint('exclude_plan(opname=\"equals\" and from_streamname=\"a\")')",
"@hint('exclude_plan(opname=\"equals\" and from_streamname=\"b\")')",
"@hint('exclude_plan(exprs[0]=\"aprop\")')"};
for (String hint : hints) {
epService.getEPAdministrator().createEPL("@Audit " + hint +
"select * from AEvent#keepall as a, BEvent#keepall as b where aprop = bprop");
}
// test subquery
SupportQueryPlanIndexHook.reset();
epService.getEPAdministrator().createEPL(INDEX_CALLBACK_HOOK + "@hint('exclude_plan(true)') select (select * from S0#unique(p00) as s0 where s1.p10 = p00) from S1 as s1");
QueryPlanIndexDescSubquery subq = SupportQueryPlanIndexHook.getAndResetSubqueries().get(0);
assertEquals(SubordFullTableScanLookupStrategyFactory.class.getSimpleName(), subq.getTableLookupStrategy());
// test named window
epService.getEPAdministrator().createEPL("create window S0Window#keepall as S0");
epService.getEPAdministrator().createEPL(INDEX_CALLBACK_HOOK + "@hint('exclude_plan(true)') on S1 as s1 select * from S0Window as s0 where s1.p10 = s0.p00");
QueryPlanIndexDescOnExpr onExpr = SupportQueryPlanIndexHook.getAndResetOnExpr();
assertEquals(SubordWMatchExprLookupStrategyFactoryAllFiltered.class.getSimpleName(), onExpr.getStrategyName());
epService.getEPAdministrator().destroyAllStatements();
}
示例3: assertOnExprAndReset
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
public static void assertOnExprAndReset(String tableName, String indexBackingClass) {
Assert.assertTrue(onexprs.size() == 1);
QueryPlanIndexDescOnExpr onexp = onexprs.get(0);
Assert.assertEquals(tableName, onexp.getTableName());
Assert.assertEquals(indexBackingClass, onexp.getIndexBackingClass());
reset();
}
示例4: runAssertionMultiIdxMultipleInAndMultirow
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
private void runAssertionMultiIdxMultipleInAndMultirow(EPServiceProvider epService) {
// assert join
SupportQueryPlanIndexHook.reset();
String epl = INDEX_CALLBACK_HOOK + "select * from S0 as s0 unidirectional, S1#keepall as s1 " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmt = epService.getEPAdministrator().createEPL(epl);
SupportUpdateListener listener = new SupportUpdateListener();
stmt.addListener(listener);
Map<TableLookupIndexReqKey, QueryPlanIndexItem> items = SupportQueryPlanIndexHook.assertJoinAndReset().getIndexSpecs()[1].getItems();
assertEquals("[p10][p11]", SupportQueryPlanIndexHelper.getIndexedExpressions(items));
tryAssertionMultiIdx(epService, listener);
epService.getEPAdministrator().destroyAllStatements();
// assert named window
epService.getEPAdministrator().createEPL("create window S1Window#keepall as S1");
epService.getEPAdministrator().createEPL("insert into S1Window select * from S1");
String eplNamedWindow = INDEX_CALLBACK_HOOK + "on S0 as s0 select * from S1Window as s1 " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmtNamedWindow = epService.getEPAdministrator().createEPL(eplNamedWindow);
stmtNamedWindow.addListener(listener);
QueryPlanIndexDescOnExpr onExprNamedWindow = SupportQueryPlanIndexHook.assertOnExprAndReset();
assertEquals(SubordInKeywordMultiTableLookupStrategyFactory.class.getSimpleName(), onExprNamedWindow.getTableLookupStrategy());
tryAssertionMultiIdx(epService, listener);
// assert table
epService.getEPAdministrator().createEPL("create table S1Table(id int primary key, p10 string primary key, p11 string primary key, p12 string primary key, p13 string primary key)");
epService.getEPAdministrator().createEPL("insert into S1Table select * from S1");
epService.getEPAdministrator().createEPL("create index S1Idx1 on S1Table(p10)");
epService.getEPAdministrator().createEPL("create index S1Idx2 on S1Table(p11)");
epService.getEPAdministrator().createEPL("create index S1Idx3 on S1Table(p12)");
epService.getEPAdministrator().createEPL("create index S1Idx4 on S1Table(p13)");
String eplTable = INDEX_CALLBACK_HOOK + "on S0 as s0 select * from S1Table as s1 " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmtTable = epService.getEPAdministrator().createEPL(eplTable);
stmtTable.addListener(listener);
QueryPlanIndexDescOnExpr onExprTable = SupportQueryPlanIndexHook.assertOnExprAndReset();
assertEquals(SubordInKeywordMultiTableLookupStrategyFactory.class.getSimpleName(), onExprTable.getTableLookupStrategy());
tryAssertionMultiIdx(epService, listener);
epService.getEPAdministrator().destroyAllStatements();
}
示例5: runAssertionSingleIdxMultipleInAndMultirow
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
private void runAssertionSingleIdxMultipleInAndMultirow(EPServiceProvider epService) {
// assert join
SupportQueryPlanIndexHook.reset();
String epl = INDEX_CALLBACK_HOOK + "select * from S0#keepall as s0, S1 as s1 unidirectional " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmt = epService.getEPAdministrator().createEPL(epl);
SupportUpdateListener listener = new SupportUpdateListener();
stmt.addListener(listener);
Map<TableLookupIndexReqKey, QueryPlanIndexItem> items = SupportQueryPlanIndexHook.assertJoinAndReset().getIndexSpecs()[0].getItems();
assertEquals("[p00]", SupportQueryPlanIndexHelper.getIndexedExpressions(items));
tryAssertionSingleIdx(epService, listener);
epService.getEPAdministrator().destroyAllStatements();
// assert named window
epService.getEPAdministrator().createEPL("create window S0Window#keepall as S0");
epService.getEPAdministrator().createEPL("insert into S0Window select * from S0");
String eplNamedWindow = INDEX_CALLBACK_HOOK + "on S1 as s1 select * from S0Window as s0 " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmtNamedWindow = epService.getEPAdministrator().createEPL(eplNamedWindow);
stmtNamedWindow.addListener(listener);
QueryPlanIndexDescOnExpr onExprNamedWindow = SupportQueryPlanIndexHook.assertOnExprAndReset();
assertEquals(SubordInKeywordSingleTableLookupStrategyFactory.class.getSimpleName(), onExprNamedWindow.getTableLookupStrategy());
tryAssertionSingleIdx(epService, listener);
// assert table
epService.getEPAdministrator().createEPL("create table S0Table(id int primary key, p00 string primary key, p01 string primary key, p02 string primary key, p03 string primary key)");
epService.getEPAdministrator().createEPL("insert into S0Table select * from S0");
epService.getEPAdministrator().createEPL("create index S0Idx1 on S0Table(p00)");
epService.getEPAdministrator().createEPL("create index S0Idx2 on S0Table(p01)");
String eplTable = INDEX_CALLBACK_HOOK + "on S1 as s1 select * from S0Table as s0 " +
"where p00 in (p10, p11) and p01 in (p12, p13)";
EPStatement stmtTable = epService.getEPAdministrator().createEPL(eplTable);
stmtTable.addListener(listener);
QueryPlanIndexDescOnExpr onExprTable = SupportQueryPlanIndexHook.assertOnExprAndReset();
assertEquals(SubordInKeywordSingleTableLookupStrategyFactory.class.getSimpleName(), onExprTable.getTableLookupStrategy());
tryAssertionSingleIdx(epService, listener);
epService.getEPAdministrator().destroyAllStatements();
}
示例6: namedWindowOnExpr
import com.espertech.esper.epl.join.util.QueryPlanIndexDescOnExpr; //导入依赖的package包/类
public void namedWindowOnExpr(QueryPlanIndexDescOnExpr onexprdesc) {
onexprs.add(onexprdesc);
}