NIFI-1010: If database driver does not support getting table name for column from ResultSetMetadata, then just use a default name

This commit is contained in:
Mark Payne 2015-10-18 22:57:04 -04:00
parent 22924c656b
commit 88fc8d28a0
1 changed files with 5 additions and 1 deletions

View File

@ -51,6 +51,7 @@ import org.apache.avro.generic.GenericData;
import org.apache.avro.generic.GenericDatumWriter; import org.apache.avro.generic.GenericDatumWriter;
import org.apache.avro.generic.GenericRecord; import org.apache.avro.generic.GenericRecord;
import org.apache.avro.io.DatumWriter; import org.apache.avro.io.DatumWriter;
import org.apache.commons.lang3.StringUtils;
/** /**
* JDBC / SQL common functions. * JDBC / SQL common functions.
@ -95,7 +96,10 @@ public class JdbcCommon {
public static Schema createSchema(final ResultSet rs) throws SQLException { public static Schema createSchema(final ResultSet rs) throws SQLException {
final ResultSetMetaData meta = rs.getMetaData(); final ResultSetMetaData meta = rs.getMetaData();
final int nrOfColumns = meta.getColumnCount(); final int nrOfColumns = meta.getColumnCount();
final String tableName = meta.getTableName(1); String tableName = meta.getTableName(1);
if (StringUtils.isBlank(tableName)) {
tableName = "NiFi_ExecuteSQL_Record";
}
final FieldAssembler<Schema> builder = SchemaBuilder.record(tableName).namespace("any.data").fields(); final FieldAssembler<Schema> builder = SchemaBuilder.record(tableName).namespace("any.data").fields();