String part_cols_str = schema.getProperty(org.apache.hadoop.hive.metastore.api.Constants.META_TABLE_PARTITION_COLUMNS);
t.setPartitionKeys(new ArrayList<FieldSchema>());
if (part_cols_str != null && (part_cols_str.trim().length() != 0)) {
String [] part_keys = part_cols_str.trim().split("/");
for (String key: part_keys) {
FieldSchema part = new FieldSchema();
part.setName(key);
part.setType(org.apache.hadoop.hive.serde.Constants.STRING_TYPE_NAME); // default partition key
t.getPartitionKeys().add(part);
}
}
t.getSd().setNumBuckets(Integer.parseInt(schema.getProperty(org.apache.hadoop.hive.metastore.api.Constants.BUCKET_COUNT, "-1")));
String bucketFieldName = schema.getProperty(org.apache.hadoop.hive.metastore.api.Constants.BUCKET_FIELD_NAME);
t.getSd().setBucketCols(new ArrayList<String>(1));
if ((bucketFieldName != null) && (bucketFieldName.trim().length() != 0)) {
t.getSd().setBucketCols(new ArrayList<String>(1));
t.getSd().getBucketCols().add(bucketFieldName);
}
t.getSd().setSerdeInfo(new SerDeInfo());
t.getSd().getSerdeInfo().setParameters(new HashMap<String, String>());
t.getSd().getSerdeInfo().setName(t.getTableName());
t.getSd().getSerdeInfo().setSerializationLib(schema.getProperty(org.apache.hadoop.hive.serde.Constants.SERIALIZATION_LIB));
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.serde.Constants.SERIALIZATION_CLASS);
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.serde.Constants.SERIALIZATION_FORMAT);
if(org.apache.commons.lang.StringUtils.isNotBlank(schema.getProperty(org.apache.hadoop.hive.serde.Constants.SERIALIZATION_CLASS))) {
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.metastore.api.Constants.META_TABLE_SERDE);
}
// needed for MetadataTypedColumnSetSerDe and LazySimpleSerDe
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.metastore.api.Constants.META_TABLE_COLUMNS);
// needed for LazySimpleSerDe
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.metastore.api.Constants.META_TABLE_COLUMN_TYPES);
// needed for DynamicSerDe
setSerdeParam(t.getSd().getSerdeInfo(), schema, org.apache.hadoop.hive.serde.Constants.SERIALIZATION_DDL);
String colstr = schema.getProperty(org.apache.hadoop.hive.metastore.api.Constants.META_TABLE_COLUMNS);
List<FieldSchema> fields = new ArrayList<FieldSchema>();
if(colstr != null) {
String[] cols = colstr.split(",");
for (String colName : cols) {
FieldSchema col = new FieldSchema(colName, org.apache.hadoop.hive.serde.Constants.STRING_TYPE_NAME, "'default'");
fields.add(col);
}
}
if(fields.size() == 0) {