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


Java TypeProtos類代碼示例

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


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

示例1: testCSVVerification_extra_column_fails

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test
public void testCSVVerification_extra_column_fails() throws Exception {
  try {
    testBuilder()
        .sqlQuery("select " + CSV_COLS + ", columns[3] as address from cp.`testframework/small_test_data_extra_col.tsv`")
        .ordered()
        .csvBaselineFile("testframework/small_test_data.tsv")
        .baselineTypes(TypeProtos.MinorType.BIGINT, TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.VARCHAR)
        .baselineColumns("employee_id", "first_name", "last_name")
        .build().run();
  } catch (AssertionError ex) {
    assertEquals("Unexpected extra column `address` returned by query.", ex.getMessage());
    // this indicates successful completion of the test
    return;
  }
  throw new Exception("Test framework verification failed, expected failure on extra column.");
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:18,代碼來源:TestFrameworkTest.java

示例2: materialize

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Override
boolean materialize(final NamedExpression ne, final VectorContainer batch, final FunctionLookupContext registry)
    throws SchemaChangeException {
  final FunctionCall call = (FunctionCall) ne.getExpr();
  final LogicalExpression input = ExpressionTreeMaterializer.materializeAndCheckErrors(call.args.get(0), batch, registry);
  if (input == null) {
    return false;
  }

  // make sure output vector type is Nullable, because we will write a null value in the first row of each partition
  TypeProtos.MajorType majorType = input.getMajorType();
  if (majorType.getMode() == TypeProtos.DataMode.REQUIRED) {
    majorType = Types.optional(majorType.getMinorType());
  }

  // add corresponding ValueVector to container
  final MaterializedField output = MaterializedField.create(ne.getRef(), majorType);
  batch.addOrGet(output).allocateNew();
  final TypedFieldId outputId =  batch.getValueVectorId(ne.getRef());

  writeInputToLead = new ValueVectorWriteExpression(outputId, input, true);
  return true;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:24,代碼來源:WindowFunction.java

示例3: allowImplicitCast

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
/**
 * Checks if implicit cast is allowed between the two input types of the join condition. Currently we allow
 * implicit casts in join condition only between numeric types and varchar/varbinary types.
 * @param input1
 * @param input2
 * @return true if implicit cast is allowed false otherwise
 */
private static boolean allowImplicitCast(TypeProtos.MinorType input1, TypeProtos.MinorType input2) {
  // allow implicit cast if both the input types are numeric
  if (TypeCastRules.isNumericType(input1) && TypeCastRules.isNumericType(input2)) {
    return true;
  }

  // allow implicit cast if input types are date/ timestamp
  if ((input1 == TypeProtos.MinorType.DATE || input1 == TypeProtos.MinorType.TIMESTAMP) &&
      (input2 == TypeProtos.MinorType.DATE || input2 == TypeProtos.MinorType.TIMESTAMP)) {
    return true;
  }

  // allow implicit cast if both the input types are varbinary/ varchar
  if ((input1 == TypeProtos.MinorType.VARCHAR || input1 == TypeProtos.MinorType.VARBINARY) &&
      (input2 == TypeProtos.MinorType.VARCHAR || input2 == TypeProtos.MinorType.VARBINARY)) {
    return true;
  }

  return false;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:28,代碼來源:JoinUtils.java

示例4: OrderedPartitionRecordBatch

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
public OrderedPartitionRecordBatch(OrderedPartitionSender pop, RecordBatch incoming, FragmentContext context) throws OutOfMemoryException {
  super(pop, context);
  this.incoming = incoming;
  this.partitions = pop.getDestinations().size();
  this.sendingMajorFragmentWidth = pop.getSendingWidth();
  this.recordsToSample = pop.getRecordsToSample();
  this.samplingFactor = pop.getSamplingFactor();
  this.completionFactor = pop.getCompletionFactor();

  DistributedCache cache = null;
  this.mmap = cache.getMultiMap(MULTI_CACHE_CONFIG);
  this.tableMap = cache.getMap(SINGLE_CACHE_CONFIG);
  Preconditions.checkNotNull(tableMap);

  this.mapKey = String.format("%s_%d", context.getHandle().getQueryId(), context.getHandle().getMajorFragmentId());
  this.minorFragmentSampleCount = cache.getCounter(mapKey);

  SchemaPath outputPath = popConfig.getRef();
  MaterializedField outputField = MaterializedField.create(outputPath, Types.required(TypeProtos.MinorType.INT));
  this.partitionKeyVector = (IntVector) TypeHelper.getNewVector(outputField, oContext.getAllocator());

}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:23,代碼來源:OrderedPartitionRecordBatch.java

示例5: testProjectWithExpressionPushDownOverUnionDistinct

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test
public void testProjectWithExpressionPushDownOverUnionDistinct() throws Exception {
  String query = "select 2 * n_nationkey as col from \n" +
      "(select n_nationkey, n_name, n_comment from cp.`tpch/nation.parquet` \n" +
      "union select r_regionkey, r_name, r_comment  from cp.`tpch/region.parquet`)";

  // Validate the result
  testBuilder()
      .sqlQuery(query)
      .unOrdered()
      .csvBaselineFile("testframework/unionDistinct/testProjectWithExpressionPushDownOverUnionDistinct.tsv")
      .baselineTypes(TypeProtos.MinorType.INT)
      .baselineColumns("col")
      .build()
      .run();
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:17,代碼來源:TestUnionDistinct.java

示例6: logFunctionResolutionError

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
private static void logFunctionResolutionError(ErrorCollector errorCollector, FunctionCall call) {
  // add error to collector
  StringBuilder sb = new StringBuilder();
  sb.append("Missing function implementation: ");
  sb.append("[");
  sb.append(call.getName());
  sb.append("(");
  boolean first = true;
  for(LogicalExpression e : call.args) {
    TypeProtos.MajorType mt = e.getMajorType();
    if (first) {
      first = false;
    } else {
      sb.append(", ");
    }
    sb.append(mt.getMinorType().name());
    sb.append("-");
    sb.append(mt.getMode().name());
  }
  sb.append(")");
  sb.append("]");

  errorCollector.addGeneralError(call.getPosition(), sb.toString());
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:25,代碼來源:ExpressionTreeMaterializer.java

示例7: TestBuilder

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
public TestBuilder(BufferAllocator allocator, String query, UserBitShared.QueryType queryType, Boolean ordered,
                   boolean approximateEquality, Map<SchemaPath, TypeProtos.MajorType> baselineTypeMap,
                   String baselineOptionSettingQueries, String testOptionSettingQueries, boolean highPerformanceComparison,
                   int expectedNumBatches) {
  this(allocator);
  if (ordered == null) {
    throw new RuntimeException("Ordering not set, when using a baseline file or query you must explicitly call the ordered() or unOrdered() method on the " + this.getClass().getSimpleName());
  }
  this.query = query;
  this.queryType = queryType;
  this.ordered = ordered;
  this.approximateEquality = approximateEquality;
  this.baselineTypeMap = baselineTypeMap;
  this.baselineOptionSettingQueries = baselineOptionSettingQueries;
  this.testOptionSettingQueries = testOptionSettingQueries;
  this.highPerformanceComparison = highPerformanceComparison;
  this.expectedNumBatches = expectedNumBatches;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:19,代碼來源:TestBuilder.java

示例8: getReturnType

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Override
public MajorType getReturnType(List<LogicalExpression> args) {

    TypeProtos.DataMode mode = returnValue.type.getMode();
    boolean nullInput = false;
    int scale = 0;
    int precision = 0;

    for (LogicalExpression e : args) {
        if (e.getMajorType().getMode() == TypeProtos.DataMode.OPTIONAL) {
            nullInput = true;
        }
        scale = Math.max(scale, e.getMajorType().getScale());
        precision = Math.max(precision, e.getMajorType().getPrecision());
    }

    if (nullHandling == NullHandling.NULL_IF_NULL && nullInput) {
        mode = TypeProtos.DataMode.OPTIONAL;
    }

    return (TypeProtos.MajorType.newBuilder().setMinorType(returnValue.type.getMinorType()).setScale(scale).setPrecision(precision).setMode(mode).build());
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:23,代碼來源:DrillDecimalMaxScaleFuncHolder.java

示例9: testGroupByUnionDistinct

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test // DRILL-3296
public void testGroupByUnionDistinct() throws Exception {
  String query = "select n_nationkey from \n" +
      "(select n_nationkey from cp.`tpch/nation.parquet` \n" +
      "union select n_nationkey from cp.`tpch/nation.parquet`) \n" +
      "group by n_nationkey";


  // Validate the plan
  final String[] expectedPlan = {"HashAgg.*\n" +
      ".*UnionAll"};
  final String[] excludedPlan = {"HashAgg.*\n.*HashAgg"};
  PlanTestBase.testPlanMatchingPatterns(query, expectedPlan, excludedPlan);

  // Validate the result
  testBuilder()
      .sqlQuery(query)
      .unOrdered()
      .csvBaselineFile("testframework/unionDistinct/testGroupByUnionDistinct.tsv")
      .baselineTypes(TypeProtos.MinorType.INT)
      .baselineColumns("n_nationkey")
      .build()
      .run();
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:25,代碼來源:TestUnionDistinct.java

示例10: getReturnType

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Override
public MajorType getReturnType(List<LogicalExpression> args) {

  int precision = 0;
  TypeProtos.DataMode mode = returnValue.type.getMode();

  if (nullHandling == NullHandling.NULL_IF_NULL) {
    // if any one of the input types is nullable, then return nullable return type
    for (LogicalExpression e : args) {
      if (e.getMajorType().getMode() == TypeProtos.DataMode.OPTIONAL) {
        mode = TypeProtos.DataMode.OPTIONAL;
      }
      precision = Math.max(precision, e.getMajorType().getPrecision());
    }
  }

  return (TypeProtos.MajorType.newBuilder().setMinorType(returnValue.type.getMinorType()).setScale(0).setPrecision(precision).setMode(mode).build());
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:19,代碼來源:DrillDecimalZeroScaleFuncHolder.java

示例11: visitValueVectorReadExpression

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
protected ValueHolder visitValueVectorReadExpression(ValueVectorReadExpression e, Integer inIndex)
    throws RuntimeException {
  TypeProtos.MajorType type = e.getMajorType();

  ValueVector vv;
  ValueHolder holder;
  try {
    switch (type.getMode()) {
      case OPTIONAL:
      case REQUIRED:
        vv = incoming.getValueAccessorById(TypeHelper.getValueVectorClass(type.getMinorType(),type.getMode()), e.getFieldId().getFieldIds()).getValueVector();
        holder = TypeHelper.getValue(vv, inIndex.intValue());
        return holder;
      default:
        throw new UnsupportedOperationException("Type of " + type + " is not supported yet in interpreted expression evaluation!");
    }
  } catch (Exception ex){
    throw new DrillRuntimeException("Error when evaluate a ValueVectorReadExpression: " + ex);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:21,代碼來源:InterpreterEvaluator.java

示例12: visitBooleanOr

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
private ValueHolder visitBooleanOr(BooleanOperator op, Integer inIndex) {
  ValueHolder [] args = new ValueHolder [op.args.size()];
  boolean hasNull = false;
  for (int i = 0; i < op.args.size(); i++) {
    args[i] = op.args.get(i).accept(this, inIndex);

    Trivalent flag = isBitOn(args[i]);

    switch (flag) {
      case TRUE:
        return op.getMajorType().getMode() == TypeProtos.DataMode.OPTIONAL? TypeHelper.nullify(ValueHolderHelper.getBitHolder(1)) : ValueHolderHelper.getBitHolder(1);
      case NULL:
        hasNull = true;
      case FALSE:
    }
  }

  if (hasNull) {
    return ValueHolderHelper.getNullableBitHolder(true, 0);
  } else {
    return op.getMajorType().getMode() == TypeProtos.DataMode.OPTIONAL? TypeHelper.nullify(ValueHolderHelper.getBitHolder(0)) : ValueHolderHelper.getBitHolder(0);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:24,代碼來源:InterpreterEvaluator.java

示例13: testUnionAll9

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test // DRILL-1905: Union-all of * column from JSON files in different directories
public void testUnionAll9() throws Exception {
  String file0 = FileUtils.getResourceAsFile("/multilevel/json/1994/Q1/orders_94_q1.json").toURI().toString();
  String file1 = FileUtils.getResourceAsFile("/multilevel/json/1995/Q1/orders_95_q1.json").toURI().toString();
  String query = String.format("select o_custkey, o_orderstatus, o_totalprice, o_orderdate, o_orderpriority, o_clerk, o_shippriority, o_comment, o_orderkey from dfs_test.`%s` union all " +
                               "select o_custkey, o_orderstatus, o_totalprice, o_orderdate, o_orderpriority, o_clerk, o_shippriority, o_comment, o_orderkey from dfs_test.`%s`", file0, file1);

  testBuilder()
      .sqlQuery(query)
      .unOrdered()
      .csvBaselineFile("testframework/testUnionAllQueries/q9.tsv")
      .baselineTypes(TypeProtos.MinorType.BIGINT, TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.FLOAT8, TypeProtos.MinorType.VARCHAR,
                     TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.BIGINT,TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.BIGINT)
      .baselineColumns("o_custkey", "o_orderstatus", "o_totalprice", "o_orderdate",
                       "o_orderpriority", "o_clerk", "o_shippriority", "o_comment", "o_orderkey")
      .build().run();
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:18,代碼來源:TestUnionAll.java

示例14: testDiffDataTypesAndModes

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test
public void testDiffDataTypesAndModes() throws Exception {
  test("use dfs_test.tmp");
  test("create view nation_view_testunionall as select n_name, n_nationkey from cp.`tpch/nation.parquet`;");
  test("create view region_view_testunionall as select r_name, r_regionkey from cp.`tpch/region.parquet`;");

  String t1 = "(select n_comment, n_regionkey from cp.`tpch/nation.parquet` limit 5)";
  String t2 = "(select * from nation_view_testunionall  limit 5)";
  String t3 = "(select full_name, store_id from cp.`employee.json` limit 5)";
  String t4 = "(select * from region_view_testunionall  limit 5)";

  String query1 = t1 + " union all " + t2 + " union all " + t3 + " union all " + t4;

  try {
    testBuilder()
        .sqlQuery(query1)
        .unOrdered()
        .csvBaselineFile("testframework/testUnionAllQueries/q13.tsv")
        .baselineTypes(TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.BIGINT)
        .baselineColumns("n_comment", "n_regionkey")
        .build().run();
  } finally {
    test("drop view nation_view_testunionall");
    test("drop view region_view_testunionall");
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:27,代碼來源:TestUnionAll.java

示例15: testUnionDistinct9

import org.apache.drill.common.types.TypeProtos; //導入依賴的package包/類
@Test // Union-Distinct of * column from JSON files in different directories
public void testUnionDistinct9() throws Exception {
  String file0 = FileUtils.getResourceAsFile("/multilevel/json/1994/Q1/orders_94_q1.json").toURI().toString();
  String file1 = FileUtils.getResourceAsFile("/multilevel/json/1995/Q1/orders_95_q1.json").toURI().toString();
  String query = String.format("select o_custkey, o_orderstatus, o_totalprice, o_orderdate, o_orderpriority, o_clerk, o_shippriority, o_comment, o_orderkey from dfs_test.`%s` union \n" +
          "select o_custkey, o_orderstatus, o_totalprice, o_orderdate, o_orderpriority, o_clerk, o_shippriority, o_comment, o_orderkey from dfs_test.`%s`", file0, file1);

  testBuilder()
      .sqlQuery(query)
      .unOrdered()
      .csvBaselineFile("testframework/unionDistinct/q9.tsv")
      .baselineTypes(TypeProtos.MinorType.BIGINT, TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.FLOAT8, TypeProtos.MinorType.VARCHAR,
          TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.BIGINT,TypeProtos.MinorType.VARCHAR, TypeProtos.MinorType.BIGINT)
      .baselineColumns("o_custkey", "o_orderstatus", "o_totalprice", "o_orderdate",
          "o_orderpriority", "o_clerk", "o_shippriority", "o_comment", "o_orderkey")
      .build()
      .run();
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:19,代碼來源:TestUnionDistinct.java


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