本文整理汇总了Java中org.apache.calcite.util.Util.first方法的典型用法代码示例。如果您正苦于以下问题:Java Util.first方法的具体用法?Java Util.first怎么用?Java Util.first使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.apache.calcite.util.Util
的用法示例。
在下文中一共展示了Util.first方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: getPredicates
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
/** @see RelMetadataQuery#getPulledUpPredicates(RelNode) */
public RelOptPredicateList getPredicates(RelSubset r,
RelMetadataQuery mq) {
if (!Bug.CALCITE_1048_FIXED) {
return RelOptPredicateList.EMPTY;
}
final RexBuilder rexBuilder = r.getCluster().getRexBuilder();
RelOptPredicateList list = null;
for (RelNode r2 : r.getRels()) {
RelOptPredicateList list2 = mq.getPulledUpPredicates(r2);
if (list2 != null) {
list = list == null ? list2 : list.union(rexBuilder, list2);
}
}
return Util.first(list, RelOptPredicateList.EMPTY);
}
示例2: visit
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public void visit(JsonFunction jsonFunction) {
// "name" is not required - a class can have several functions
checkRequiredAttributes(jsonFunction, "className");
try {
final SchemaPlus schema = currentMutableSchema("function");
final List<String> path =
Util.first(jsonFunction.path, currentSchemaPath());
create(schema,
jsonFunction.name,
path,
jsonFunction.className,
jsonFunction.methodName);
} catch (Exception e) {
throw new RuntimeException("Error instantiating " + jsonFunction, e);
}
}
示例3: columnStrategies
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
/** Helper for {@link #getColumnStrategies()}. */
public static List<ColumnStrategy> columnStrategies(final RelOptTable table) {
final int fieldCount = table.getRowType().getFieldCount();
final InitializerExpressionFactory ief =
Util.first(table.unwrap(InitializerExpressionFactory.class),
NullInitializerExpressionFactory.INSTANCE);
return new AbstractList<ColumnStrategy>() {
public int size() {
return fieldCount;
}
public ColumnStrategy get(int index) {
return ief.generationStrategy(table, index);
}
};
}
示例4: collation
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
private static RelFieldCollation collation(RexNode node,
RelFieldCollation.Direction direction,
RelFieldCollation.NullDirection nullDirection, List<RexNode> extraNodes) {
switch (node.getKind()) {
case INPUT_REF:
return new RelFieldCollation(((RexInputRef) node).getIndex(), direction,
Util.first(nullDirection, direction.defaultNullDirection()));
case DESCENDING:
return collation(((RexCall) node).getOperands().get(0),
RelFieldCollation.Direction.DESCENDING,
nullDirection, extraNodes);
case NULLS_FIRST:
return collation(((RexCall) node).getOperands().get(0), direction,
RelFieldCollation.NullDirection.FIRST, extraNodes);
case NULLS_LAST:
return collation(((RexCall) node).getOperands().get(0), direction,
RelFieldCollation.NullDirection.LAST, extraNodes);
default:
final int fieldIndex = extraNodes.size();
extraNodes.add(node);
return new RelFieldCollation(fieldIndex, direction,
Util.first(nullDirection, direction.defaultNullDirection()));
}
}
示例5: HepPlanner
import org.apache.calcite.util.Util; //导入方法依赖的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;
}
示例6: create
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public Schema create(SchemaPlus parentSchema, String name,
Map<String, Object> operand) {
Map map = (Map) operand;
double scale = Util.first((Double) map.get("scale"), 1D);
int part = Util.first((Integer) map.get("part"), 1);
int partCount = Util.first((Integer) map.get("partCount"), 1);
boolean columnPrefix = Util.first((Boolean) map.get("columnPrefix"), true);
return new TpchSchema(scale, part, partCount, columnPrefix);
}
示例7: create
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public Schema create(SchemaPlus parentSchema, String name,
Map<String, Object> operand) {
Map map = (Map) operand;
double scale = Util.first((Double) map.get("scale"), 1D);
int part = Util.first((Integer) map.get("part"), 1);
int partCount = Util.first((Integer) map.get("partCount"), 1);
boolean columnPrefix = Util.first((Boolean) map.get("columnPrefix"), true);
return new TpcdsSchema(scale, part, partCount);
}
示例8: estimateJoinedRows
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
/** @deprecated Use {@link RelMdUtil#getJoinRowCount(RelMetadataQuery, Join, RexNode)}. */
@Deprecated // to be removed before 2.0
public static double estimateJoinedRows(
Join joinRel,
RexNode condition) {
final RelMetadataQuery mq = RelMetadataQuery.instance();
return Util.first(RelMdUtil.getJoinRowCount(mq, joinRel, condition), 1D);
}
示例9: toRel
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public RelNode toRel(final RelOptTable table) {
final RelNode scan = table.toRel(createToRelContext());
final InitializerExpressionFactory ief =
Util.first(table.unwrap(InitializerExpressionFactory.class),
NullInitializerExpressionFactory.INSTANCE);
// Lazily create a blackboard that contains all non-generated columns.
final Supplier<Blackboard> bb = new Supplier<Blackboard>() {
public Blackboard get() {
RexNode sourceRef = rexBuilder.makeRangeReference(scan);
return createInsertBlackboard(table, sourceRef,
table.getRowType().getFieldNames());
}
};
int virtualCount = 0;
final List<RexNode> list = new ArrayList<>();
for (RelDataTypeField f : table.getRowType().getFieldList()) {
final ColumnStrategy strategy =
ief.generationStrategy(table, f.getIndex());
switch (strategy) {
case VIRTUAL:
list.add(ief.newColumnDefaultValue(table, f.getIndex(), bb.get()));
++virtualCount;
break;
default:
list.add(
rexBuilder.makeInputRef(scan,
RelOptTableImpl.realOrdinal(table, f.getIndex())));
}
}
if (virtualCount > 0) {
relBuilder.push(scan);
relBuilder.project(list);
return relBuilder.build();
}
return scan;
}
示例10: explain
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
@Override public void explain(RelWriter pw) {
// Not a typical implementation of "explain". We don't gather terms &
// values to be printed later. We actually do the work.
String s = getDescription();
pw.item("subset", s);
final AbstractRelNode input =
(AbstractRelNode) Util.first(getBest(), getOriginal());
if (input == null) {
return;
}
input.explainTerms(pw);
pw.done(input);
}
示例11: SubstitutionVisitor
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public SubstitutionVisitor(RelNode target_, RelNode query_,
ImmutableList<UnifyRule> rules, RelBuilderFactory relBuilderFactory) {
this.cluster = target_.getCluster();
final RexExecutor executor =
Util.first(cluster.getPlanner().getExecutor(), RexUtil.EXECUTOR);
final RelOptPredicateList predicates = RelOptPredicateList.EMPTY;
this.simplify =
new RexSimplify(cluster.getRexBuilder(), predicates, false, executor);
this.rules = rules;
this.query = Holder.of(MutableRels.toMutable(query_));
this.target = MutableRels.toMutable(target_);
this.relBuilder = relBuilderFactory.create(cluster, null);
final Set<MutableRel> parents = Sets.newIdentityHashSet();
final List<MutableRel> allNodes = new ArrayList<>();
final MutableRelVisitor visitor =
new MutableRelVisitor() {
public void visit(MutableRel node) {
parents.add(node.getParent());
allNodes.add(node);
super.visit(node);
}
};
visitor.go(target);
// Populate the list of leaves in the tree under "target".
// Leaves are all nodes that are not parents.
// For determinism, it is important that the list is in scan order.
allNodes.removeAll(parents);
targetLeaves = ImmutableList.copyOf(allNodes);
allNodes.clear();
parents.clear();
visitor.go(query);
allNodes.removeAll(parents);
queryLeaves = ImmutableList.copyOf(allNodes);
}
示例12: create
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
public static MockModifiableViewRelOptTable create(MockModifiableViewTable modifiableViewTable,
MockCatalogReader catalogReader, String catalogName, String schemaName, String name,
boolean stream, double rowCount, ColumnResolver resolver) {
final Table underlying = modifiableViewTable.unwrap(Table.class);
final InitializerExpressionFactory initializerExpressionFactory =
underlying != null && underlying instanceof Wrapper
? ((Wrapper) underlying).unwrap(InitializerExpressionFactory.class)
: NullInitializerExpressionFactory.INSTANCE;
return new MockModifiableViewRelOptTable(modifiableViewTable,
catalogReader, catalogName, schemaName, name, stream, rowCount,
resolver, Util.first(initializerExpressionFactory,
NullInitializerExpressionFactory.INSTANCE));
}
示例13: estimateRowCount
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
@Override public double estimateRowCount(RelMetadataQuery mq) {
return Util.first(RelMdUtil.getJoinRowCount(mq, this, condition), 1D);
}
示例14: estimateRowCount
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
@Override public double estimateRowCount(RelMetadataQuery mq) {
return Util.first(
RelMdUtil.getSemiJoinRowCount(mq, left, right, joinType, condition),
1D);
}
示例15: getUnit
import org.apache.calcite.util.Util; //导入方法依赖的package包/类
/** Returns {@code SECOND} for both {@code HOUR TO SECOND} and
* {@code SECOND}. */
public TimeUnit getUnit() {
return Util.first(timeUnitRange.endUnit, timeUnitRange.startUnit);
}