mirror of https://github.com/apache/nifi.git
NIFI-9800: Unwrap SQLException in PutDatabaseRecord when table does not exist
Signed-off-by: Matthew Burgess <mattyb149@apache.org> This closes #5871
This commit is contained in:
parent
2dc23e7309
commit
c84f438782
|
@ -604,18 +604,29 @@ public class PutDatabaseRecord extends AbstractProcessor {
|
||||||
}
|
}
|
||||||
|
|
||||||
final SchemaKey schemaKey = new PutDatabaseRecord.SchemaKey(catalog, schemaName, tableName);
|
final SchemaKey schemaKey = new PutDatabaseRecord.SchemaKey(catalog, schemaName, tableName);
|
||||||
final TableSchema tableSchema = schemaCache.get(schemaKey, key -> {
|
final TableSchema tableSchema;
|
||||||
|
try {
|
||||||
|
tableSchema = schemaCache.get(schemaKey, key -> {
|
||||||
try {
|
try {
|
||||||
final TableSchema schema = TableSchema.from(con, catalog, schemaName, tableName, settings.translateFieldNames, updateKeys, log);
|
final TableSchema schema = TableSchema.from(con, catalog, schemaName, tableName, settings.translateFieldNames, updateKeys, log);
|
||||||
getLogger().debug("Fetched Table Schema {} for table name {}", schema, tableName);
|
getLogger().debug("Fetched Table Schema {} for table name {}", schema, tableName);
|
||||||
return schema;
|
return schema;
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
|
// Wrap this in a runtime exception, it is unwrapped in the outer try
|
||||||
throw new ProcessException(e);
|
throw new ProcessException(e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (tableSchema == null) {
|
if (tableSchema == null) {
|
||||||
throw new IllegalArgumentException("No table schema specified!");
|
throw new IllegalArgumentException("No table schema specified!");
|
||||||
}
|
}
|
||||||
|
} catch (ProcessException pe) {
|
||||||
|
// Unwrap the SQLException if one occurred
|
||||||
|
if (pe.getCause() instanceof SQLException) {
|
||||||
|
throw (SQLException) pe.getCause();
|
||||||
|
} else {
|
||||||
|
throw pe;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// build the fully qualified table name
|
// build the fully qualified table name
|
||||||
final String fqTableName = generateTableName(settings, catalog, schemaName, tableName, tableSchema);
|
final String fqTableName = generateTableName(settings, catalog, schemaName, tableName, tableSchema);
|
||||||
|
|
Loading…
Reference in New Issue