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


Java Function2類代碼示例

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


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

示例1: execute

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
@Override
public StatementExecutionResult execute(TableSpaceManager tableSpaceManager,
        TransactionContext transactionContext,
        StatementEvaluationContext context, boolean lockRequired, boolean forWrite) throws StatementExecutionException {
    ScanResult resLeft = (ScanResult) left.execute(tableSpaceManager, transactionContext,
            context, lockRequired, forWrite);
    transactionContext = new TransactionContext(resLeft.transactionId);
    ScanResult resRight = (ScanResult) right.execute(tableSpaceManager, transactionContext,
            context, lockRequired, forWrite);
    final long resTransactionId = resRight.transactionId;
    final String[] fieldNamesFromLeft = resLeft.dataScanner.getFieldNames();
    final String[] fieldNamesFromRight = resRight.dataScanner.getFieldNames();
    final Function2<DataAccessor, DataAccessor, DataAccessor> resultProjection = resultProjection(fieldNamesFromLeft, fieldNamesFromRight);

    Enumerable<DataAccessor> result = EnumerableDefaults.thetaJoin(resLeft.dataScanner.createEnumerable(),
            resRight.dataScanner.createEnumerable(),
            predicate(resultProjection, context), resultProjection,
            generateNullsOnLeft,
            generateNullsOnRight
    );
    EnumerableDataScanner joinedScanner = new EnumerableDataScanner(resTransactionId, fieldNames, columns, result);
    return new ScanResult(resTransactionId, joinedScanner);

}
 
開發者ID:diennea,項目名稱:herddb,代碼行數:25,代碼來源:ThetaJoinOp.java

示例2: createCopyHook

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
private Function2<RelNode, RelNode, Void> createCopyHook() {
	return new Function2<RelNode, RelNode, Void>() {
		public Void apply(RelNode oldNode, RelNode newNode) {
			if (cm.mapRefRelToCorVar.containsKey(oldNode)) {
				cm.mapRefRelToCorVar.putAll(newNode, cm.mapRefRelToCorVar.get(oldNode));
			}
			if (oldNode instanceof LogicalCorrelate && newNode instanceof LogicalCorrelate) {
				LogicalCorrelate oldCor = (LogicalCorrelate) oldNode;
				CorrelationId c = oldCor.getCorrelationId();
				if (cm.mapCorVarToCorRel.get(c) == oldNode) {
					cm.mapCorVarToCorRel.put(c, newNode);
				}

				if (generatedCorRels.contains(oldNode)) {
					generatedCorRels.add((LogicalCorrelate) newNode);
				}
			}
			return null;
		}
	};
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:22,代碼來源:FlinkRelDecorrelator.java

示例3: join

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
/**
 * Correlates the elements of two sequences based on
 * matching keys. A specified {@code EqualityComparer<TSource>} is used to
 * compare keys.
 */
public static <TSource, TInner, TKey, TResult> Enumerable<TResult> join(
    Enumerable<TSource> outer, Enumerable<TInner> inner,
    Function1<TSource, TKey> outerKeySelector,
    Function1<TInner, TKey> innerKeySelector,
    Function2<TSource, TInner, TResult> resultSelector,
    EqualityComparer<TKey> comparer, boolean generateNullsOnLeft,
    boolean generateNullsOnRight) {
  return join_(
      outer,
      inner,
      outerKeySelector,
      innerKeySelector,
      resultSelector,
      comparer,
      generateNullsOnLeft,
      generateNullsOnRight);
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:23,代碼來源:EnumerableDefaults.java

示例4: mergeJoin

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
/** Joins two inputs that are sorted on the key. */
public static <TSource, TInner, TKey extends Comparable<TKey>, TResult> Enumerable<TResult>
    mergeJoin(final Enumerable<TSource> outer,
    final Enumerable<TInner> inner,
    final Function1<TSource, TKey> outerKeySelector,
    final Function1<TInner, TKey> innerKeySelector,
    final Function2<TSource, TInner, TResult> resultSelector,
    boolean generateNullsOnLeft,
    boolean generateNullsOnRight) {
  assert !generateNullsOnLeft : "not implemented";
  assert !generateNullsOnRight : "not implemented";
  return new AbstractEnumerable<TResult>() {
    public Enumerator<TResult> enumerator() {
      return new MergeJoinEnumerator<>(outer.enumerator(),
          inner.enumerator(), outerKeySelector, innerKeySelector,
          resultSelector);
    }
  };
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:20,代碼來源:EnumerableDefaults.java

示例5: testSelectManyWithIndexableSelector

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
@Test public void testSelectManyWithIndexableSelector() {
  final int[] indexRef = new int[]{0};
  final List<String> nameSeqs =
      Linq4j.asEnumerable(depts)
          .selectMany(new Function2<Department, Integer, Enumerable<Employee>>() {
            public Enumerable<Employee> apply(Department element, Integer index) {
              assertEquals(indexRef[0], index.longValue());
              indexRef[0] = index + 1;
              return Linq4j.asEnumerable(element.employees);
            }
          })
          .select(
              new Function2<Employee, Integer, String>() {
                public String apply(Employee v1, Integer v2) {
                  return "#" + v2 + ": " + v1.name;
                }
              })
          .toList();
  assertEquals(
      "[#0: Fred, #1: Eric, #2: Janet, #3: Bill]", nameSeqs.toString());
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:22,代碼來源:Linq4jTest.java

示例6: testGroupByWithKeySelectorAndResultSelector

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
@Test public void testGroupByWithKeySelectorAndResultSelector() {
  String s =
      Linq4j.asEnumerable(emps)
          .groupBy(EMP_DEPTNO_SELECTOR, new Function2<Integer, Enumerable<Employee>, String>() {
            public String apply(Integer key, Enumerable<Employee> group) {
              return String.format(Locale.ROOT, "%s: %s", key,
                  stringJoin("+", group.select(new Function1<Employee, String>() {
                    public String apply(Employee element) {
                      return element.name;
                    }
                  })));
            }
          })
          .toList()
          .toString();
  assertEquals(
      "[10: Fred+Eric+Janet, 30: Bill]",
      s);
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:20,代碼來源:Linq4jTest.java

示例7: HepPlanner

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
/**
 * Creates a new HepPlanner with the option to keep the graph a
 * tree(noDAG=true) or allow DAG(noDAG=false).
 *
 * @param program    program controlling rule application
 * @param onCopyHook Function to call when a node is copied
 */
public HepPlanner(
    HepProgram program,
    Context context,
    boolean noDAG,
    Function2<RelNode, RelNode, Void> onCopyHook,
    RelOptCostFactory costFactory) {
  super(costFactory, context);
  this.mainProgram = program;
  this.onCopyHook =
      Util.first(onCopyHook, Functions.<RelNode, RelNode, Void>ignore2());
  mapDigestToVertex = new HashMap<>();
  graph = DefaultDirectedGraph.create();

  // NOTE jvs 24-Apr-2006:  We use LinkedHashSet here and below
  // in order to provide deterministic behavior.
  allRules = new LinkedHashSet<>();
  this.noDAG = noDAG;
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:26,代碼來源:HepPlanner.java

示例8: createCopyHook

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
private Function2<RelNode, RelNode, Void> createCopyHook() {
  return new Function2<RelNode, RelNode, Void>() {
    public Void apply(RelNode oldNode, RelNode newNode) {
      if (cm.mapRefRelToCorRef.containsKey(oldNode)) {
        cm.mapRefRelToCorRef.putAll(newNode,
            cm.mapRefRelToCorRef.get(oldNode));
      }
      if (oldNode instanceof LogicalCorrelate
          && newNode instanceof LogicalCorrelate) {
        LogicalCorrelate oldCor = (LogicalCorrelate) oldNode;
        CorrelationId c = oldCor.getCorrelationId();
        if (cm.mapCorToCorRel.get(c) == oldNode) {
          cm.mapCorToCorRel.put(c, newNode);
        }

        if (generatedCorRels.contains(oldNode)) {
          generatedCorRels.add((LogicalCorrelate) newNode);
        }
      }
      return null;
    }
  };
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:24,代碼來源:RelDecorrelator.java

示例9: groupBy

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
/**
 * Groups the elements of a sequence according to a
 * specified key selector function, initializing an accumulator for each
 * group and adding to it each time an element with the same key is seen.
 * Creates a result value from each accumulator and its key using a
 * specified function. Key values are compared by using a
 * specified comparer.
 */
public static <TSource, TKey, TAccumulate, TResult> Enumerable<TResult> groupBy(
    Enumerable<TSource> enumerable, Function1<TSource, TKey> keySelector,
    Function0<TAccumulate> accumulatorInitializer,
    Function2<TAccumulate, TSource, TAccumulate> accumulatorAdder,
    Function2<TKey, TAccumulate, TResult> resultSelector,
    EqualityComparer<TKey> comparer) {
  return groupBy_(
      new WrapMap<>(
        new Function0<Map<Wrapped<TKey>, TAccumulate>>() {
          public Map<Wrapped<TKey>, TAccumulate> apply() {
            return new HashMap<>();
          }
        },
        comparer),
      enumerable,
      keySelector,
      accumulatorInitializer,
      accumulatorAdder,
      resultSelector);
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:29,代碼來源:EnumerableDefaults.java

示例10: testGroupByWithKeySelectorAndElementSelectorAndResultSelector

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
@Test public void testGroupByWithKeySelectorAndElementSelectorAndResultSelector() {
  String s =
      Linq4j.asEnumerable(emps)
          .groupBy(EMP_DEPTNO_SELECTOR, EMP_NAME_SELECTOR,
              new Function2<Integer, Enumerable<String>, String>() {
                public String apply(Integer key, Enumerable<String> group) {
                  return String.format(Locale.ROOT, "%s: %s", key,
                      stringJoin("+", group));
                }
              })
          .toList()
          .toString();
  assertEquals(
      "[10: Fred+Eric+Janet, 30: Bill]",
      s);
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:17,代碼來源:Linq4jTest.java

示例11: predicate

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
private Predicate2<DataAccessor, DataAccessor> predicate(
        Function2<DataAccessor, DataAccessor, DataAccessor> projection,
        StatementEvaluationContext context) {
    return (DataAccessor v0, DataAccessor v1) -> {
        DataAccessor currentRow = projection.apply(v0, v1);
        return SQLRecordPredicate.toBoolean(condition.evaluate(currentRow, context));
    };
}
 
開發者ID:diennea,項目名稱:herddb,代碼行數:9,代碼來源:ThetaJoinOp.java

示例12: resultProjection

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
private Function2<DataAccessor, DataAccessor, DataAccessor> resultProjection(
        String[] fieldNamesFromLeft,
        String[] fieldNamesFromRight) {
    final DataAccessor nullsOnLeft = DataAccessor.ALL_NULLS(fieldNamesFromLeft);
    final DataAccessor nullsOnRight = DataAccessor.ALL_NULLS(fieldNamesFromRight);

    return (DataAccessor a, DataAccessor b)
            -> new ConcatenatedDataAccessor(fieldNames,
                    a != null ? a : nullsOnLeft,
                    b != null ? b : nullsOnRight);

}
 
開發者ID:diennea,項目名稱:herddb,代碼行數:13,代碼來源:ThetaJoinOp.java

示例13: resultProjection

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
private Function2<DataAccessor, DataAccessor, DataAccessor> resultProjection(
        String[] fieldNamesFromLeft,
        String[] fieldNamesFromRight) {
    DataAccessor nullsOnLeft = DataAccessor.ALL_NULLS(fieldNamesFromLeft);
    DataAccessor nullsOnRight = DataAccessor.ALL_NULLS(fieldNamesFromRight);

    return (DataAccessor a, DataAccessor b)
            -> new ConcatenatedDataAccessor(fieldNames,
                    a != null ? a : nullsOnLeft,
                    b != null ? b : nullsOnRight);
}
 
開發者ID:diennea,項目名稱:herddb,代碼行數:12,代碼來源:JoinOp.java

示例14: testGroupJoin

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
@Test public void testGroupJoin() {
  // Note #1: Group join is a "left join": "bad employees" are filtered
  //   out, but empty departments are not.
  // Note #2: Order of departments is preserved.
  String s =
      Linq4j.asEnumerable(depts)
          .groupJoin(
              Linq4j.asEnumerable(emps)
                  .concat(Linq4j.asEnumerable(badEmps)),
              DEPT_DEPTNO_SELECTOR,
              EMP_DEPTNO_SELECTOR,
              new Function2<Department, Enumerable<Employee>, String>() {
                public String apply(Department v1, Enumerable<Employee> v2) {
                  final StringBuilder buf = new StringBuilder("[");
                  int n = 0;
                  for (Employee employee : v2) {
                    if (n++ > 0) {
                      buf.append(", ");
                    }
                    buf.append(employee.name);
                  }
                  return buf.append("] work(s) in ").append(v1.name)
                      .toString();
                }
              })
          .toList()
          .toString();
  assertEquals(
      "[[Fred, Eric, Janet] work(s) in Sales, "
          + "[] work(s) in HR, "
          + "[Bill] work(s) in Marketing]",
      s);
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:34,代碼來源:Linq4jTest.java

示例15: groupJoin

import org.apache.calcite.linq4j.function.Function2; //導入依賴的package包/類
public <TInner, TKey, TResult> Queryable<TResult> groupJoin(
    Queryable<T> source,
    Enumerable<TInner> inner,
    FunctionExpression<Function1<T, TKey>> outerKeySelector,
    FunctionExpression<Function1<TInner, TKey>> innerKeySelector,
    FunctionExpression<Function2<T, Enumerable<TInner>, TResult>>
        resultSelector) {
  throw new UnsupportedOperationException();
}
 
開發者ID:apache,項目名稱:calcite,代碼行數:10,代碼來源:QueryableRelBuilder.java


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