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


Java TypeProtos.MajorType方法代碼示例

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


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

示例1: interpreterDateTest

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterDateTest() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.INT)};
  final String expressionStr = "now()";
  final BitControl.PlanFragment planFragment = BitControl.PlanFragment.getDefaultInstance();
  final QueryContextInformation queryContextInfo = planFragment.getContext();
  final int                        timeZoneIndex = queryContextInfo.getTimeZone();
  final org.joda.time.DateTimeZone timeZone = org.joda.time.DateTimeZone.forID(org.apache.drill.exec.expr.fn.impl.DateUtility.getTimeZone(timeZoneIndex));
  final org.joda.time.DateTime     now = new org.joda.time.DateTime(queryContextInfo.getQueryStartTime(), timeZone);

  final long queryStartDate = now.getMillis();

  final TimeStampHolder out = new TimeStampHolder();

  out.value = queryStartDate;

  final ByteBuffer buffer = ByteBuffer.allocate(12);
  buffer.putLong(out.value);
  final long l = buffer.getLong(0);
  final DateTime t = new DateTime(l);

  final String[] expectedFirstTwoValues = {t.toString(), t.toString()};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues, planFragment);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:27,代碼來源:ExpressionInterpreterTest.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: 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

示例4: 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

示例5: interpreterNullableStrExpr

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterNullableStrExpr() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.VARCHAR)};
  final String expressionStr =  "substr(col1, 1, 3)";
  final String[] expectedFirstTwoValues = {"aaa", "null"};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:10,代碼來源:ExpressionInterpreterTest.java

示例6: interpreterNullableIntegerExpr

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterNullableIntegerExpr() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.INT)};
  final String expressionStr = "col1 + 100 - 1 * 2 + 2";
  final String[] expectedFirstTwoValues = {"-2147483548", "null"};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:10,代碼來源:ExpressionInterpreterTest.java

示例7: resolveHash

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
public void resolveHash(DrillConfig config, LogicalExpression arg, TypeProtos.MajorType expectedArg,
                                  TypeProtos.MajorType expectedOut, TypeProtos.DataMode expectedBestInputMode,
                                  FunctionImplementationRegistry registry) throws JClassAlreadyExistsException, IOException {
  final List<LogicalExpression> args = new ArrayList<>();
  args.add(arg);
  final String[] registeredNames = { "hash" };
  FunctionCall call = new FunctionCall(
      "hash",
      args,
      ExpressionPosition.UNKNOWN
  );
  final FunctionResolver resolver = FunctionResolverFactory.getResolver(call);
  final DrillFuncHolder matchedFuncHolder = registry.findDrillFunction(resolver, call);
  assertEquals( expectedBestInputMode, matchedFuncHolder.getParmMajorType(0).getMode());
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:16,代碼來源:TestSimpleFunctions.java

示例8: BaselineQueryTestBuilder

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
BaselineQueryTestBuilder(String baselineQuery, UserBitShared.QueryType baselineQueryType, BufferAllocator allocator,
                         String query, UserBitShared.QueryType queryType, Boolean ordered,
                         boolean approximateEquality, Map<SchemaPath, TypeProtos.MajorType> baselineTypeMap,
                         String baselineOptionSettingQueries, String testOptionSettingQueries, boolean highPerformanceComparison,
                         int expectedNumBatches) {
  super(allocator, query, queryType, ordered, approximateEquality, baselineTypeMap, baselineOptionSettingQueries, testOptionSettingQueries,
      highPerformanceComparison, expectedNumBatches);
  this.baselineQuery = baselineQuery;
  this.baselineQueryType = baselineQueryType;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:11,代碼來源:TestBuilder.java

示例9: interpreterCaseExpr

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterCaseExpr() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.VARCHAR)};
  final String expressionStr =  "case when substr(col1, 1, 3)='aaa' then 'ABC' else 'XYZ' end";
  final String[] expectedFirstTwoValues = {"ABC", "XYZ"};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:10,代碼來源:ExpressionInterpreterTest.java

示例10: addTypeInfoIfMissing

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
private void addTypeInfoIfMissing(QueryDataBatch batch, TestBuilder testBuilder) {
  if (! testBuilder.typeInfoSet()) {
    Map<SchemaPath, TypeProtos.MajorType> typeMap = getTypeMapFromBatch(batch);
    testBuilder.baselineTypes(typeMap);
  }

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

示例11: toMajorType

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
public static TypeProtos.MajorType toMajorType(PrimitiveType.PrimitiveTypeName primitiveTypeName, int length,
                                        TypeProtos.DataMode mode, SchemaElement schemaElement,
                                        OptionManager options) {
  MinorType minorType = getMinorType(primitiveTypeName, length, schemaElement, options);
  TypeProtos.MajorType.Builder typeBuilder = TypeProtos.MajorType.newBuilder().setMinorType(minorType).setMode(mode);

  if (CoreDecimalUtility.isDecimalType(minorType)) {
    typeBuilder.setPrecision(schemaElement.getPrecision()).setScale(schemaElement.getScale());
  }
  return typeBuilder.build();
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:12,代碼來源:ParquetToDrillTypeConverter.java

示例12: interpreterLikeExpr

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterLikeExpr() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.VARCHAR)};
  final String expressionStr =  "like(col1, 'aaa%')";
  final String[] expectedFirstTwoValues = {"true", "null"};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:10,代碼來源:ExpressionInterpreterTest.java

示例13: interpreterNullableBooleanExpr

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void interpreterNullableBooleanExpr() throws Exception {
  final String[] colNames = {"col1"};
  final TypeProtos.MajorType[] colTypes = {Types.optional(TypeProtos.MinorType.VARCHAR)};
  final String expressionStr =  "col1 < 'abc' and col1 > 'abc'";
  final String[] expectedFirstTwoValues = {"false", "null"};

  doTest(expressionStr, colNames, colTypes, expectedFirstTwoValues);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:10,代碼來源:ExpressionInterpreterTest.java

示例14: testCSVVerificationTypeMap

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Test
public void testCSVVerificationTypeMap() throws Throwable {
  Map<SchemaPath, TypeProtos.MajorType> typeMap = new HashMap<>();
  typeMap.put(TestBuilder.parsePath("first_name"), Types.optional(TypeProtos.MinorType.VARCHAR));
  typeMap.put(TestBuilder.parsePath("employee_id"), Types.optional(TypeProtos.MinorType.INT));
  typeMap.put(TestBuilder.parsePath("last_name"), Types.optional(TypeProtos.MinorType.VARCHAR));
  testBuilder()
      .sqlQuery("select cast(columns[0] as int) employee_id, columns[1] as first_name, columns[2] as last_name from cp.`testframework/small_test_data_reordered.tsv`")
      .unOrdered()
      .csvBaselineFile("testframework/small_test_data.tsv")
      .baselineColumns("employee_id", "first_name", "last_name")
      // This should work without this line because of the default type casts added based on the types that come out of the test query.
      // To write a test that enforces strict typing you must pass type information using a CSV with a list of types,
      // or any format with a Map of types like is constructed above and include the call to pass it into the test, which is commented out below
      //.baselineTypes(typeMap)
      .build().run();

  typeMap.clear();
  typeMap.put(TestBuilder.parsePath("first_name"), Types.optional(TypeProtos.MinorType.VARCHAR));
  // This is the wrong type intentionally to ensure failures happen when expected
  typeMap.put(TestBuilder.parsePath("employee_id"), Types.optional(TypeProtos.MinorType.VARCHAR));
  typeMap.put(TestBuilder.parsePath("last_name"), Types.optional(TypeProtos.MinorType.VARCHAR));

  try {
  testBuilder()
      .sqlQuery("select cast(columns[0] as int) employee_id, columns[1] as first_name, columns[2] as last_name from cp.`testframework/small_test_data_reordered.tsv`")
      .unOrdered()
      .csvBaselineFile("testframework/small_test_data.tsv")
      .baselineColumns("employee_id", "first_name", "last_name")
      .baselineTypes(typeMap)
      .build().run();
  } catch (Exception ex) {
    // this indicates successful completion of the test
    return;
  }
  throw new Exception("Test framework verification failed, expected failure on type check.");
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:38,代碼來源:TestFrameworkTest.java

示例15: getVectorType

import org.apache.drill.common.types.TypeProtos; //導入方法依賴的package包/類
@Override
public TypeProtos.MajorType getVectorType(SchemaPath column, PlannerSettings plannerSettings) {
  return ((ParquetGroupScan) scanRel.getGroupScan()).getTypeForColumn(column);
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:5,代碼來源:ParquetPartitionDescriptor.java


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