private void calculateMultipleSourcesSubSchemas() throws TupleMRException {
Criteria commonSortCriteria = mrConfig.getCommonCriteria();
List<Field> commonFields = new ArrayList<Field>();
for(SortElement sortElement : commonSortCriteria.getElements()) {
String fieldName = sortElement.getName();
Field field = checkFieldInAllSchemas(fieldName);
commonFields.add(field);
}
this.commonSchema = new Schema("common", commonFields);
this.specificSchemas = new ArrayList<Schema>();
List<List<Field>> specificFieldsBySource = new ArrayList<List<Field>>();
for(int schemaId = 0; schemaId < mrConfig.getNumIntermediateSchemas(); schemaId++) {
Criteria specificCriteria = mrConfig.getSpecificOrderBys().get(schemaId);
List<Field> specificFields = new ArrayList<Field>();
if(specificCriteria != null) {
for(SortElement sortElement : specificCriteria.getElements()) {
String fieldName = sortElement.getName();
Field field = checkFieldInSchema(fieldName, schemaId);
specificFields.add(field);
}
}
specificFieldsBySource.add(specificFields);
}
for(int i = 0; i < mrConfig.getNumIntermediateSchemas(); i++) {
Schema sourceSchema = mrConfig.getIntermediateSchema(i);
List<Field> specificFields = specificFieldsBySource.get(i);
for(Field field : sourceSchema.getFields()) {
if(!commonSchema.containsField(field.getName())
&& !containsFieldName(field.getName(), specificFields)) {
specificFields.add(field);
}
}
this.specificSchemas.add(new Schema("specific", specificFields));