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


Java ArrowType類代碼示例

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


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

示例1: visitGeneric

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@Override
protected String visitGeneric(ArrowType type) {
  String typeStr = describe(type);
  if(!includeName) {
    return typeStr;
  }

  return field.getName() + "::" + typeStr;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:10,代碼來源:Describer.java

示例2: union

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
public static CompleteType union(Iterable<Field> fields){
  ImmutableList<Field> listOfFields = ImmutableList.copyOf(fields);
  int[] typeIds = new int[listOfFields.size()];
  for (int i =0; i < typeIds.length; i++) {
    typeIds[i] = MajorTypeHelper.getArrowMinorType(CompleteType.fromField(listOfFields.get(i)).toMinorType()).ordinal();
  }
  return new CompleteType(new ArrowType.Union(UnionMode.Sparse, typeIds), listOfFields);
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:9,代碼來源:CompleteType.java

示例3: GlobalDictionaryFieldInfo

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@JsonCreator
public GlobalDictionaryFieldInfo(
  @JsonProperty("dictionaryVersion") long dictionaryVersion,
  @JsonProperty("fieldName") String fieldName,
  @JsonProperty("storagePluginId") StoragePluginId storagePluginId,
  @JsonProperty("arrowType") ArrowType arrowType,
  @JsonProperty("dictionaryPath") String dictionaryPath) {
  this(dictionaryVersion, fieldName, storagePluginId, arrowType, dictionaryPath, null);
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:10,代碼來源:GlobalDictionaryFieldInfo.java

示例4: visit

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@Override
public Field visit(ArrowType.List type) {
  if(field.getName().equals(column.getAsUnescapedPath())){
    Field child = field.getChildren().get(0);
    return new Field(field.getName(), child.isNullable(), child.getType(), child.getChildren());
  }
  return field;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:9,代碼來源:FlattenPOP.java

示例5: visitGeneric

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@Override
public Field visitGeneric(ArrowType type) {
  if(field.getName().equals(column.getAsUnescapedPath())){
    throw UserException.validationError().message("You're trying to flatten a field that is not a list. The offending field is %s.", Describer.describe(field)).build(logger);
  }
  return super.visitGeneric(type);
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:8,代碼來源:FlattenPOP.java

示例6: buildIntegerGlobalDictionary

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static VectorContainer buildIntegerGlobalDictionary(List<Dictionary> dictionaries, VectorContainer existingDict, ColumnDescriptor columnDescriptor, BufferAllocator bufferAllocator) {
  final Field field = new Field(SchemaPath.getCompoundPath(columnDescriptor.getPath()).getAsUnescapedPath(), true, new ArrowType.Int(32, true), null);
  final VectorContainer input = new VectorContainer(bufferAllocator);
  final NullableIntVector intVector = input.addOrGet(field);
  intVector.allocateNew();
  final SortedSet<Integer> values = Sets.newTreeSet();
  for (Dictionary dictionary : dictionaries) {
    for (int i = 0; i <= dictionary.getMaxId(); ++i) {
      values.add(dictionary.decodeToInt(i));
    }
  }
  if (existingDict != null) {
    final NullableIntVector existingDictValues = existingDict.getValueAccessorById(NullableIntVector.class, 0).getValueVector();
    for (int i = 0; i < existingDict.getRecordCount(); ++i) {
      values.add(existingDictValues.getAccessor().get(i));
    }
  }
  final Iterator<Integer> iter = values.iterator();
  int recordCount = 0;
  while (iter.hasNext()) {
    intVector.getMutator().setSafe(recordCount++, iter.next());
  }
  intVector.getMutator().setValueCount(recordCount);
  input.setRecordCount(recordCount);
  input.buildSchema(BatchSchema.SelectionVectorMode.NONE);
  return input;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:28,代碼來源:GlobalDictionaryBuilder.java

示例7: buildLongGlobalDictionary

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static VectorContainer buildLongGlobalDictionary(List<Dictionary> dictionaries, VectorContainer existingDict, ColumnDescriptor columnDescriptor, BufferAllocator bufferAllocator) {
  final Field field = new Field(SchemaPath.getCompoundPath(columnDescriptor.getPath()).getAsUnescapedPath(), true, new ArrowType.Int(64, true), null);
  final VectorContainer input = new VectorContainer(bufferAllocator);
  final NullableBigIntVector longVector = input.addOrGet(field);
  longVector.allocateNew();
  SortedSet<Long> values = Sets.newTreeSet();
  for (Dictionary dictionary : dictionaries) {
    for (int i = 0; i <= dictionary.getMaxId(); ++i) {
      values.add(dictionary.decodeToLong(i));
    }
  }
  if (existingDict != null) {
    final NullableBigIntVector existingDictValues = existingDict.getValueAccessorById(NullableBigIntVector.class, 0).getValueVector();
    for (int i = 0; i < existingDict.getRecordCount(); ++i) {
      values.add(existingDictValues.getAccessor().get(i));
    }
  }
  final Iterator<Long> iter = values.iterator();
  int recordCount = 0;
  while (iter.hasNext()) {
    longVector.getMutator().setSafe(recordCount++, iter.next());
  }
  longVector.getMutator().setValueCount(recordCount);
  input.setRecordCount(recordCount);
  input.buildSchema(BatchSchema.SelectionVectorMode.NONE);
  return input;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:28,代碼來源:GlobalDictionaryBuilder.java

示例8: buildDoubleGlobalDictionary

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static VectorContainer buildDoubleGlobalDictionary(List<Dictionary> dictionaries, VectorContainer existingDict, ColumnDescriptor columnDescriptor, BufferAllocator bufferAllocator) {
  final Field field = new Field(SchemaPath.getCompoundPath(columnDescriptor.getPath()).getAsUnescapedPath(), true, new ArrowType.FloatingPoint(FloatingPointPrecision.DOUBLE), null);
  final VectorContainer input = new VectorContainer(bufferAllocator);
  final NullableFloat8Vector doubleVector = input.addOrGet(field);
  doubleVector.allocateNew();
  SortedSet<Double> values = Sets.newTreeSet();
  for (Dictionary dictionary : dictionaries) {
    for (int i = 0; i <= dictionary.getMaxId(); ++i) {
      values.add(dictionary.decodeToDouble(i));
    }
  }
  if (existingDict != null) {
    final NullableFloat8Vector existingDictValues = existingDict.getValueAccessorById(NullableFloat8Vector.class, 0).getValueVector();
    for (int i = 0; i < existingDict.getRecordCount(); ++i) {
      values.add(existingDictValues.getAccessor().get(i));
    }
  }
  final Iterator<Double> iter = values.iterator();
  int recordCount = 0;
  while (iter.hasNext()) {
    doubleVector.getMutator().setSafe(recordCount++, iter.next());
  }
  doubleVector.getMutator().setValueCount(recordCount);
  input.setRecordCount(recordCount);
  input.buildSchema(BatchSchema.SelectionVectorMode.NONE);
  return input;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:28,代碼來源:GlobalDictionaryBuilder.java

示例9: buildFloatGlobalDictionary

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static VectorContainer buildFloatGlobalDictionary(List<Dictionary> dictionaries, VectorContainer existingDict, ColumnDescriptor columnDescriptor, BufferAllocator bufferAllocator) {
  final Field field = new Field(SchemaPath.getCompoundPath(columnDescriptor.getPath()).getAsUnescapedPath(), true, new ArrowType.FloatingPoint(FloatingPointPrecision.SINGLE), null);
  final VectorContainer input = new VectorContainer(bufferAllocator);
  final NullableFloat4Vector floatVector = input.addOrGet(field);
  floatVector.allocateNew();
  SortedSet<Float> values = Sets.newTreeSet();
  for (Dictionary dictionary : dictionaries) {
    for (int i = 0; i <= dictionary.getMaxId(); ++i) {
      values.add(dictionary.decodeToFloat(i));
    }
  }
  if (existingDict != null) {
    final NullableFloat4Vector existingDictValues = existingDict.getValueAccessorById(NullableFloat4Vector.class, 0).getValueVector();
    for (int i = 0; i < existingDict.getRecordCount(); ++i) {
      values.add(existingDictValues.getAccessor().get(i));
    }
  }
  final Iterator<Float> iter = values.iterator();
  int recordCount = 0;
  while (iter.hasNext()) {
    floatVector.getMutator().setSafe(recordCount++, iter.next());
  }
  floatVector.getMutator().setValueCount(recordCount);
  input.setRecordCount(recordCount);
  input.buildSchema(BatchSchema.SelectionVectorMode.NONE);
  return input;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:28,代碼來源:GlobalDictionaryBuilder.java

示例10: buildBinaryGlobalDictionary

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static VectorContainer buildBinaryGlobalDictionary(List<Dictionary> dictionaries, VectorContainer existingDict, ColumnDescriptor columnDescriptor, BufferAllocator bufferAllocator) {
  final Field field = new Field(SchemaPath.getCompoundPath(columnDescriptor.getPath()).getAsUnescapedPath(), true, new ArrowType.Binary(), null);
  final VectorContainer input = new VectorContainer(bufferAllocator);
  final NullableVarBinaryVector binaryVector = input.addOrGet(field);
  binaryVector.allocateNew();
  final SortedSet<Binary> values = new TreeSet<>();
  for (Dictionary dictionary : dictionaries) {
    for (int i = 0; i <= dictionary.getMaxId(); ++i) {
      values.add(dictionary.decodeToBinary(i));
    }
  }
  if (existingDict != null) {
    final NullableVarBinaryVector existingDictValues = existingDict.getValueAccessorById(NullableVarBinaryVector.class, 0).getValueVector();
    for (int i = 0; i < existingDict.getRecordCount(); ++i) {
      values.add(Binary.fromConstantByteArray(existingDictValues.getAccessor().get(i)));
    }
  }
  final Iterator<Binary> iter = values.iterator();
  int recordCount = 0;
  while (iter.hasNext()) {
    final byte[] data = iter.next().getBytes();
    binaryVector.getMutator().setSafe(recordCount++, data, 0, data.length);
  }
  binaryVector.getMutator().setValueCount(recordCount);
  input.setRecordCount(recordCount);
  input.buildSchema(BatchSchema.SelectionVectorMode.NONE);
  return input;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:29,代碼來源:GlobalDictionaryBuilder.java

示例11: getOutputType

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
public CompleteType getOutputType(CompleteType baseReturn, List<LogicalExpression> args) {
  Preconditions.checkArgument(args.size() == 1);
  CompleteType type = args.get(0).getCompleteType();
  if(!type.isStruct()){
    throw UserException.functionError().message("The kvgen function can only be used when operating against maps. The type you were attempting to apply it to was a %s.", type.toString()).build(logger);
  }

  List<Field> children = type.getChildren();

  if(children.isEmpty()){
    throw UserException.functionError().message("The kvgen function can only be used when operating against maps. The type you were attempting to apply it to was a %s.", type.toString()).build(logger);
  }


  CompleteType valueType = CompleteType.fromField(children.get(0));
  for(int i =0; i < children.size(); i++){
    valueType = valueType.merge(CompleteType.fromField(children.get(i)));
  }

  return new CompleteType(
      ArrowType.List.INSTANCE,
      new CompleteType(
          ArrowType.Struct.INSTANCE,
          CompleteType.VARCHAR.toField(MappifyUtility.fieldKey),
          valueType.toField(MappifyUtility.fieldValue))
      .toField("list"));
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:28,代碼來源:Mappify.java

示例12: newDataset

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private static SourceTableDefinition newDataset(final String dsPath) {
  final List<String> path = SqlUtils.parseSchemaPath(dsPath);

  SourceTableDefinition ret = mock(SourceTableDefinition.class);
  NamespaceKey datasetName = new NamespaceKey(path);
  when(ret.getName()).thenReturn(datasetName);

  BatchSchema schema = BatchSchema.newBuilder()
    .addField(new Field("string", FieldType.nullable(ArrowType.Utf8.INSTANCE), null))
    .build();
  DatasetConfig dsConfig = new DatasetConfig()
    .setName(Util.last(path))
    .setFullPathList(path)
    .setType(DatasetType.PHYSICAL_DATASET_SOURCE_FILE)
    .setRecordSchema(ByteString.EMPTY)
    .setPhysicalDataset(
      new PhysicalDataset()
        .setFormatSettings(null))
    .setSchemaVersion(DatasetHelper.CURRENT_VERSION)
    .setRecordSchema(schema.toByteString())
    .setReadDefinition(new ReadDefinition());
  try {
    when(ret.getDataset()).thenReturn(dsConfig);
  } catch (Exception ex) {}

  when(ret.getType()).thenReturn(DatasetType.PHYSICAL_DATASET_SOURCE_FILE);

  when(ret.isSaveable()).thenReturn(true);
  return ret;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:31,代碼來源:TestStoragePluginRegistryImpl.java

示例13: assertDatasetSchemasDefined

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
private void assertDatasetSchemasDefined(List<NamespaceKey> datasetKeys) throws Exception {
  for (NamespaceKey datasetKey : datasetKeys) {
    DatasetConfig dsConfig = ns.getDataset(datasetKey);
    BatchSchema schema = BatchSchema.deserialize(dsConfig.getRecordSchema());
    assertEquals(schema.getFieldCount(), 1);
    assertEquals(schema.getColumn(0).getName(), "string");
    assertEquals(schema.getColumn(0).getType(), ArrowType.Utf8.INSTANCE);
  }
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:10,代碼來源:TestStoragePluginRegistryImpl.java

示例14: trueWhenAllColumnsAreSelected

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@Test
public void trueWhenAllColumnsAreSelected() {
  BatchSchema schema = mock(BatchSchema.class);
  when(schema.iterator())
      .thenReturn(Lists.newArrayList(Field.nullable("a1", new ArrowType.Bool())).iterator());
  assertTrue(EasyScanOperatorCreator.selectsAllColumns(schema,
      Lists.<SchemaPath>newArrayList(SchemaPath.getSimplePath("a1"))));
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:9,代碼來源:TestEasyScanOperatorCreator.java

示例15: selectionIgnoresIncremental

import org.apache.arrow.vector.types.pojo.ArrowType; //導入依賴的package包/類
@Test
public void selectionIgnoresIncremental() {
  BatchSchema schema = mock(BatchSchema.class);
  when(schema.iterator())
      .thenReturn(Lists.newArrayList(Field.nullable("a1", new ArrowType.Bool()),
          Field.nullable(IncrementalUpdateUtils.UPDATE_COLUMN, new ArrowType.Bool())).iterator());
  assertTrue(EasyScanOperatorCreator.selectsAllColumns(schema,
    Lists.<SchemaPath>newArrayList(SchemaPath.getSimplePath("a1"))));
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:10,代碼來源:TestEasyScanOperatorCreator.java


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