当前位置: 首页>>代码示例>>Java>>正文


Java StructTypeInfo类代码示例

本文整理汇总了Java中org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo的典型用法代码示例。如果您正苦于以下问题:Java StructTypeInfo类的具体用法?Java StructTypeInfo怎么用?Java StructTypeInfo使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


StructTypeInfo类属于org.apache.hadoop.hive.serde2.typeinfo包,在下文中一共展示了StructTypeInfo类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: getFromTypeInfo

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
public static OrcSerde getFromTypeInfo( final Configuration config , final TypeInfo typeInfo )throws IOException{
  ObjectInspector objectInspector = TypeInfoUtils.getStandardJavaObjectInspectorFromTypeInfo( typeInfo );
  if( !( typeInfo instanceof StructTypeInfo ) ){
    throw new IOException( "Input type info is not StructTypeInfo : " + typeInfo.toString() );
  }
  String columnsName = "";
  String columnsType = "";
  List<TypeInfo> typeInfoList = ( (StructTypeInfo)typeInfo ).getAllStructFieldTypeInfos();
  List<StructField> structField = (List<StructField>)( ( (StructObjectInspector)objectInspector ).getAllStructFieldRefs() );
  for( int i = 0 ; i < structField.size() ; i++ ){
    if( ! columnsName.isEmpty() ){
      columnsName = columnsName.concat( "," );
      columnsType = columnsType.concat( "," );
    }
    columnsName = columnsName.concat( structField.get(i).getFieldName() );
    columnsType = columnsType.concat( typeInfoList.get(i).toString() );
  }

  OrcSerde serde = new OrcSerde();
  Properties table = new Properties();
  table.setProperty( serdeConstants.LIST_COLUMNS , columnsName );
  table.setProperty( serdeConstants.LIST_COLUMN_TYPES , columnsType );
  serde.initialize( config , table );

  return serde;
}
 
开发者ID:yahoojapan,项目名称:dataplatform-schema-lib,代码行数:27,代码来源:OrcSerdeFactory.java

示例2: getAllReadTypeInfo

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
private StructTypeInfo getAllReadTypeInfo( final String columnNameProperty , final String columnTypeProperty ){
  ArrayList<TypeInfo> fieldTypes = TypeInfoUtils.getTypeInfosFromTypeString( columnTypeProperty );
  ArrayList<String> columnNames = new ArrayList<String>();
  if ( columnNameProperty != null && 0 < columnNameProperty.length() ) {
    String[] columnNameArray = columnNameProperty.split(",");
    for( int i = 0 ; i < columnNameArray.length ; i++ ){
      columnNames.add( columnNameArray[i] );
      filedIndexMap.put( columnNameArray[i] , i );
    }
  }
  StructTypeInfo rootType = new StructTypeInfo();

  rootType.setAllStructFieldNames( columnNames );
  rootType.setAllStructFieldTypeInfos( fieldTypes );

  return rootType;
}
 
开发者ID:yahoojapan,项目名称:multiple-dimension-spread,代码行数:18,代码来源:MDSSerde.java

示例3: getColumnProjectionTypeInfo

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
private StructTypeInfo getColumnProjectionTypeInfo( final String columnNameProperty , final String columnTypeProperty , final String projectionColumnNames ){
  Set<String> columnNameSet = new HashSet<String>();
  for( String columnName : projectionColumnNames.split(",") ){
    columnNameSet.add( columnName );
  }

  ArrayList<TypeInfo> fieldTypes = TypeInfoUtils.getTypeInfosFromTypeString( columnTypeProperty );
  String[] splitNames = columnNameProperty.split(",");

  ArrayList<String> projectionColumnNameList = new ArrayList<String>();
  ArrayList<TypeInfo> projectionFieldTypeList = new ArrayList<TypeInfo>();
  for( int i = 0 ; i < fieldTypes.size() ; i++ ){
    if( columnNameSet.contains( splitNames[i] ) ){
      projectionColumnNameList.add( splitNames[i] );
      projectionFieldTypeList.add( fieldTypes.get(i) );
    }
    filedIndexMap.put( splitNames[i] , i );
  }
  StructTypeInfo rootType = new StructTypeInfo();

  rootType.setAllStructFieldNames( projectionColumnNameList );
  rootType.setAllStructFieldTypeInfos( projectionFieldTypeList );

  return rootType;
}
 
开发者ID:yahoojapan,项目名称:multiple-dimension-spread,代码行数:26,代码来源:MDSSerde.java

示例4: initialize

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
@Override
public void initialize( final Configuration conf, final Properties table , final Properties part ) throws SerDeException{
  LOG.info( table.toString() );
  if( part != null ){
    LOG.info( part.toString() );
  }
  String columnNameProperty = table.getProperty(serdeConstants.LIST_COLUMNS);
  String columnTypeProperty = table.getProperty(serdeConstants.LIST_COLUMN_TYPES);

  String projectionColumnNames = conf.get( ColumnProjectionUtils.READ_COLUMN_NAMES_CONF_STR , "" );

  StructTypeInfo rootType;
  if( projectionColumnNames.isEmpty() ){
    rootType = getAllReadTypeInfo( columnNameProperty , columnTypeProperty );
  }
  else{
    rootType = getColumnProjectionTypeInfo( columnNameProperty , columnTypeProperty , projectionColumnNames );
  }

  inspector = MDSObjectInspectorFactory.craeteObjectInspectorFromTypeInfo( rootType );
}
 
开发者ID:yahoojapan,项目名称:multiple-dimension-spread,代码行数:22,代码来源:MDSSerde.java

示例5: HiveStructSchema

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
public HiveStructSchema( final StructContainerField schema ) throws IOException{
  this.schema = schema;

  StructTypeInfo structSchema = new StructTypeInfo();
  ArrayList<String> childKey = new ArrayList<String>();
  ArrayList<TypeInfo> childTypeInfo = new ArrayList<TypeInfo>();
  for( String key : schema.getKeys() ){
    TypeInfo typeInfo = HiveSchemaFactory.getHiveSchema( schema.get( key ) );
    childKey.add( key );
    childTypeInfo.add( typeInfo );
  }
  structSchema.setAllStructFieldNames( childKey );
  structSchema.setAllStructFieldTypeInfos( childTypeInfo );

  hiveSchema = structSchema;
}
 
开发者ID:yahoojapan,项目名称:dataplatform-schema-lib,代码行数:17,代码来源:HiveStructSchema.java

示例6: toMetacatType

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
@Override
public Type toMetacatType(final String type) {
    // Hack to fix presto "varchar" type coming in with no length which is required by Hive.
    final TypeInfo typeInfo = TypeInfoUtils.getTypeInfoFromTypeString(
        "varchar".equals(type.toLowerCase()) ? serdeConstants.STRING_TYPE_NAME : type);
    ObjectInspector oi = TypeInfoUtils.getStandardJavaObjectInspectorFromTypeInfo(typeInfo);
    // The standard struct object inspector forces field names to lower case, however in Metacat we need to preserve
    // the original case of the struct fields so we wrap it with our wrapper to force the fieldNames to keep
    // their original case
    if (typeInfo.getCategory().equals(ObjectInspector.Category.STRUCT)) {
        final StructTypeInfo structTypeInfo = (StructTypeInfo) typeInfo;
        final StandardStructObjectInspector objectInspector = (StandardStructObjectInspector) oi;
        oi = new HiveTypeConverter.SameCaseStandardStructObjectInspector(
            structTypeInfo.getAllStructFieldNames(), objectInspector);
    }
    return getCanonicalType(oi);
}
 
开发者ID:Netflix,项目名称:metacat,代码行数:18,代码来源:HiveTypeConverter.java

示例7: createStructObjectInspector

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
public static LazySimpleStructObjectInspector createStructObjectInspector(TypeInfo type,
			LazySerDeParameters serdeParams) {
		StructTypeInfo structTypeInfo = (StructTypeInfo) type;
		List<String> fieldNames = structTypeInfo.getAllStructFieldNames();
		List<TypeInfo> fieldTypeInfos = structTypeInfo.getAllStructFieldTypeInfos();
		List<ObjectInspector> fieldObjectInspectors = new ArrayList<ObjectInspector>(fieldTypeInfos.size());

		for (int i = 0; i < fieldTypeInfos.size(); i++) {
			fieldObjectInspectors.add(createObjectInspector(fieldTypeInfos.get(i), serdeParams));
		}

		 return LazyObjectInspectorFactory.getLazySimpleStructObjectInspector(
			 fieldNames, fieldObjectInspectors, null,
			 serdeParams.getSeparators()[1],
			 serdeParams, ObjectInspectorOptions.JAVA);

//		return ObjectInspectorFactory.getStandardStructObjectInspector(fieldNames, fieldObjectInspectors);
	}
 
开发者ID:mini666,项目名称:hive-phoenix-handler,代码行数:19,代码来源:PhoenixObjectInspectorFactory.java

示例8: deserializeStruct

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
private Object deserializeStruct(StructTypeInfo type, Object data)
        throws SerDeException {
    if (!(data instanceof Map)) {
        throw new SerDeException("Value not of type map");
    }
    //noinspection unchecked
    Map<String, Object> map = (Map<String, Object>) data;

    List<String> fieldNames = type.getAllStructFieldNames();
    List<TypeInfo> fieldTypes = type.getAllStructFieldTypeInfos();

    // When deserializing a struct the returned value is a list of values in the same order as the field names.

    List<Object> values = Lists.newArrayListWithCapacity(fieldNames.size());
    for (int i=0; i < fieldNames.size(); i++) {
        Object rawValue = getRawValueOrNullIfAbsent(fieldNames.get(i), map);
        Object value = deserialize(fieldTypes.get(i), rawValue);
        values.add(value);
    }

    return values;
}
 
开发者ID:bazaarvoice,项目名称:emodb,代码行数:23,代码来源:EmoSerDe.java

示例9: ArrayWritableObjectInspector

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
public ArrayWritableObjectInspector(final StructTypeInfo rowTypeInfo) {

        typeInfo = rowTypeInfo;
        fieldNames = rowTypeInfo.getAllStructFieldNames();
        fieldInfos = rowTypeInfo.getAllStructFieldTypeInfos();
        fields = new ArrayList<StructField>(fieldNames.size());
        fieldsByName = new HashMap<String, StructFieldImpl>();

        for (int i = 0; i < fieldNames.size(); ++i) {
            final String name = fieldNames.get(i);
            final TypeInfo fieldInfo = fieldInfos.get(i);

            final StructFieldImpl field = new StructFieldImpl(name, getObjectInspector(fieldInfo), i);
            fields.add(field);
            fieldsByName.put(name, field);
        }
    }
 
开发者ID:shunfei,项目名称:indexr,代码行数:18,代码来源:ArrayWritableObjectInspector.java

示例10: isSupportedType

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
public static boolean isSupportedType(TypeInfo typeInfo)
{
    switch (typeInfo.getCategory()) {
        case PRIMITIVE:
            PrimitiveObjectInspector.PrimitiveCategory primitiveCategory = ((PrimitiveTypeInfo) typeInfo).getPrimitiveCategory();
            return getPrimitiveType(primitiveCategory) != null;
        case MAP:
            MapTypeInfo mapTypeInfo = checkType(typeInfo, MapTypeInfo.class, "typeInfo");
            return isSupportedType(mapTypeInfo.getMapKeyTypeInfo()) && isSupportedType(mapTypeInfo.getMapValueTypeInfo());
        case LIST:
            ListTypeInfo listTypeInfo = checkType(typeInfo, ListTypeInfo.class, "typeInfo");
            return isSupportedType(listTypeInfo.getListElementTypeInfo());
        case STRUCT:
            StructTypeInfo structTypeInfo = checkType(typeInfo, StructTypeInfo.class, "typeInfo");
            return structTypeInfo.getAllStructFieldTypeInfos().stream()
                    .allMatch(HiveType::isSupportedType);
    }
    return false;
}
 
开发者ID:y-lan,项目名称:presto,代码行数:20,代码来源:HiveType.java

示例11: readFullyReadSchemaFromSplit

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
@Test
public void readFullyReadSchemaFromSplit() throws IOException {
  StructTypeInfo typeInfo = new StructTypeInfoBuilder()
      .add("a", TypeInfoFactory.stringTypeInfo)
      .add("b", TypeInfoFactory.stringTypeInfo)
      .build();
  CorcInputFormat.setTypeInfo(conf, typeInfo);
  CorcInputFormat.setConverterFactoryClass(conf, DefaultConverterFactory.class);

  RecordReader<NullWritable, Corc> reader = inputFormat.getRecordReader(split, conf, reporter);

  Corc corc = reader.createValue();

  reader.next(NullWritable.get(), corc);
  assertThat(corc.get("a"), is((Object) "A1"));
  assertThat(corc.get("b"), is((Object) "B1"));
  reader.close();
}
 
开发者ID:HotelsDotCom,项目名称:corc,代码行数:19,代码来源:CorcInputFormatTest.java

示例12: readFullyDeclaredSchema

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
@Test
public void readFullyDeclaredSchema() throws IOException {
  StructTypeInfo typeInfo = new StructTypeInfoBuilder()
      .add("a", TypeInfoFactory.stringTypeInfo)
      .add("b", TypeInfoFactory.stringTypeInfo)
      .build();
  CorcInputFormat.setTypeInfo(conf, typeInfo);
  CorcInputFormat.setSchemaTypeInfo(conf, typeInfo);
  CorcInputFormat.setConverterFactoryClass(conf, DefaultConverterFactory.class);

  RecordReader<NullWritable, Corc> reader = inputFormat.getRecordReader(split, conf, reporter);

  Corc corc = reader.createValue();

  reader.next(NullWritable.get(), corc);
  assertThat(corc.get("a"), is((Object) "A1"));
  assertThat(corc.get("b"), is((Object) "B1"));
  reader.close();
}
 
开发者ID:HotelsDotCom,项目名称:corc,代码行数:20,代码来源:CorcInputFormatTest.java

示例13: newFields

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
static Fields newFields(StructTypeInfo structTypeInfo) {
  List<String> existingNames = structTypeInfo.getAllStructFieldNames();
  List<String> namesList = new ArrayList<>(existingNames.size());
  namesList.addAll(existingNames);
  String[] names = namesList.toArray(new String[namesList.size()]);

  List<TypeInfo> typeInfos = structTypeInfo.getAllStructFieldTypeInfos();
  Class<?>[] types = new Class[typeInfos.size()];
  for (int i = 0; i < types.length; i++) {
    Class<?> type = PRIMITIVES.get(typeInfos.get(i));
    if (type == null) {
      type = Object.class;
    }
    types[i] = type;
  }

  return new Fields(names, types);
}
 
开发者ID:HotelsDotCom,项目名称:corc,代码行数:19,代码来源:SchemaFactory.java

示例14: newStructTypeInfo

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
static StructTypeInfo newStructTypeInfo(Fields fields) {
  List<String> names = new ArrayList<>();
  List<TypeInfo> typeInfos = new ArrayList<>();

  for (int i = 0; i < fields.size(); i++) {
    String name = fields.get(i).toString();
    if (ROW_ID_NAME.equals(name)) {
      if (!fields.getTypeClass(i).equals(RecordIdentifier.class)) {
        throw new IllegalArgumentException(ROW_ID_NAME + " column is not of type "
            + RecordIdentifier.class.getSimpleName() + ". Found type: " + fields.getTypeClass(i));
      }
      continue;
    }
    names.add(name.toLowerCase());
    Class<?> type = fields.getTypeClass(i);
    if (type == null) {
      throw new IllegalArgumentException("Missing type information for field: " + name);
    }

    TypeInfo typeInfo = getTypeInfoFromClass(type);
    typeInfos.add(typeInfo);
  }

  return (StructTypeInfo) TypeInfoFactory.getStructTypeInfo(names, typeInfos);
}
 
开发者ID:HotelsDotCom,项目名称:corc,代码行数:26,代码来源:SchemaFactory.java

示例15: createTypeInfo

import org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo; //导入依赖的package包/类
private StructTypeInfo createTypeInfo() {
  return new StructTypeInfoBuilder()
      .add("a", TypeInfoFactory.stringTypeInfo)
      .add("b", TypeInfoFactory.booleanTypeInfo)
      .add("c", TypeInfoFactory.byteTypeInfo)
      .add("d", TypeInfoFactory.shortTypeInfo)
      .add("e", TypeInfoFactory.intTypeInfo)
      .add("f", TypeInfoFactory.longTypeInfo)
      .add("g", TypeInfoFactory.floatTypeInfo)
      .add("h", TypeInfoFactory.doubleTypeInfo)
      .add("i", TypeInfoFactory.timestampTypeInfo)
      .add("j", TypeInfoFactory.dateTypeInfo)
      .add("k", TypeInfoFactory.binaryTypeInfo)
      .add("l", TypeInfoFactory.decimalTypeInfo)
      .add("m", TypeInfoFactory.getListTypeInfo(TypeInfoFactory.intTypeInfo))
      .add("n", TypeInfoFactory.getMapTypeInfo(TypeInfoFactory.intTypeInfo, TypeInfoFactory.intTypeInfo))
      .add("o", new StructTypeInfoBuilder().add("a", TypeInfoFactory.intTypeInfo).build())
      .add("p", TypeInfoFactory.getUnionTypeInfo(Arrays.asList((TypeInfo) TypeInfoFactory.stringTypeInfo)))
      .build();
}
 
开发者ID:HotelsDotCom,项目名称:corc,代码行数:21,代码来源:OrcFileSinkPerformanceTest.java


注:本文中的org.apache.hadoop.hive.serde2.typeinfo.StructTypeInfo类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。