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


Java DataType.isAtomic方法代码示例

本文整理汇总了Java中org.apache.pig.data.DataType.isAtomic方法的典型用法代码示例。如果您正苦于以下问题:Java DataType.isAtomic方法的具体用法?Java DataType.isAtomic怎么用?Java DataType.isAtomic使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.pig.data.DataType的用法示例。


在下文中一共展示了DataType.isAtomic方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: containsByteArrayOrEmtpyInSchema

import org.apache.pig.data.DataType; //导入方法依赖的package包/类
/**
 * @param fs
 * @return true if fs is of complex type and contains a bytearray 
 *  or empty inner schema
 * @throws FrontendException
 */
private boolean containsByteArrayOrEmtpyInSchema(LogicalFieldSchema fs)
throws FrontendException {
    
    if(fs.type == DataType.BYTEARRAY)
        return true;
    
    if(DataType.isAtomic(fs.type))
        return false;
    
    if(fs.schema == null || fs.schema.size() == 0)
        return true;
    
    for(LogicalFieldSchema inFs : fs.schema.getFields()){
        if(containsByteArrayOrEmtpyInSchema(inFs))
            return true;
    }

    return false;
}
 
开发者ID:sigmoidanalytics,项目名称:spork-streaming,代码行数:26,代码来源:CastLineageSetter.java

示例2: getDescription

import org.apache.pig.data.DataType; //导入方法依赖的package包/类
private String getDescription(boolean printAlias) {
    StringBuilder sb = new StringBuilder();
    if (printAlias && this.name != null)
        sb.append(this.name).append(":");
    if (DataType.isAtomic(this.type)) {
        sb.append(DataType.findTypeName(this.type));
    } else {
        //if (this.schema!=null)
            stringifyResourceSchema(sb, this.schema, this.type, printAlias);
    }
    return sb.toString();
}
 
开发者ID:sigmoidanalytics,项目名称:spork-streaming,代码行数:13,代码来源:ResourceSchema.java

示例3: extractField

import org.apache.pig.data.DataType; //导入方法依赖的package包/类
@Override
protected Object extractField(Object target) {
    List<String> fieldNames = getFieldNames();
    for (int index = 0; index < fieldNames.size(); index++) {
        String fieldName = fieldNames.get(index);
        if (target instanceof PigTuple) {
            PigTuple pt = (PigTuple) target;
            ResourceFieldSchema[] fields = pt.getSchema().getSchema().getFields();

            boolean foundField = false;
            for (int i = 0; i < fields.length && !foundField; i++) {
                ResourceFieldSchema field = fields[i];
                if (fieldName.equals(field.getName())) {
                    foundField = true;
                    byte type = field.getType();
                    try {
                        Object object = pt.getTuple().get(i);
                        if (DataType.isAtomic(type)) {
                            target = object.toString();
                        }
                        else if (type == DataType.TUPLE) {
                            PigTuple rpt = new PigTuple(field.getSchema());
                            if (object instanceof PigTuple) {
                                rpt.setTuple(((PigTuple) object).getTuple());
                            }
                            else {
                                rpt.setTuple((Tuple) object);
                            }
                            target = rpt;
                        }
                        else {
                            Assert.isTrue(false, String.format("Unsupported data type [%s] for field [%s]; use only 'primitives' or 'tuples'", DataType.findTypeName(type), fieldName));
                        }
                    } catch (ExecException ex) {
                        throw new EsHadoopIllegalStateException(String.format("Cannot retrieve field [%s]", fieldName), ex);
                    }
                }
            }
        }
        else {
            return NOT_FOUND;
        }
    }
    return target;
}
 
开发者ID:xushjie1987,项目名称:es-hadoop-v2.2.0,代码行数:46,代码来源:PigFieldExtractor.java

示例4: stringifySchema

import org.apache.pig.data.DataType; //导入方法依赖的package包/类
public static void stringifySchema(StringBuilder sb,
                                   Schema schema,
                                   byte type,
                                   int indentLevel)
                                        throws FrontendException{

    if (type == DataType.TUPLE) {
        sb.append("(") ;
    }
    else if (type == DataType.BAG) {
        sb.append("{") ;
    }

    indentLevel++;

    if (schema != null) {
        boolean isFirst = true ;
        for (int i=0; i< schema.size() ;i++) {

            if (!isFirst) {
                sb.append(",") ;
            }
            else {
                isFirst = false ;
            }

            indent(sb, indentLevel);

            FieldSchema fs = schema.getField(i) ;

            if(fs == null) {
                continue;
            }
            
            if (fs.alias != null) {
                sb.append(fs.alias);
                sb.append(": ");
            }

            if (DataType.isAtomic(fs.type)) {
                sb.append(DataType.findTypeName(fs.type)) ;
            }
            else if ( (fs.type == DataType.TUPLE) ||
                      (fs.type == DataType.BAG) ) {
                // safety net
                if (schema != fs.schema) {
                    stringifySchema(sb, fs.schema, fs.type, indentLevel) ;
                }
                else {
                    throw new AssertionError("Schema refers to itself "
                                             + "as inner schema") ;
                }
            } else if (fs.type == DataType.MAP) {
                sb.append(DataType.findTypeName(fs.type) + "[");
                if (fs.schema!=null)
                    stringifySchema(sb, fs.schema, fs.type, indentLevel);
                sb.append("]");
            } else {
                sb.append(DataType.findTypeName(fs.type)) ;
            }
        }
    }

    indentLevel--;
    indent(sb, indentLevel);

    if (type == DataType.TUPLE) {
        sb.append(")") ;
    }
    else if (type == DataType.BAG) {
        sb.append("}") ;
    }

}
 
开发者ID:sigmoidanalytics,项目名称:spork-streaming,代码行数:75,代码来源:Schema.java


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