Michael Pigott created ARROW-4144:
-------------------------------------
Summary: [Java] Arrow-to-JDBC
Key: ARROW-4144
URL: https://issues.apache.org/jira/browse/ARROW-4144
Project: Apache Arrow
Issue Type: Improvement
Components: Java
Reporter: Michael Pigott
ARROW-1780 reads a query from a JDBC data source and converts the ResultSet to
an Arrow VectorSchemaRoot. However, there is no built-in adapter for writing
an Arrow VectorSchemaRoot back to the database.
ARROW-3966 adds JDBC field metadata:
* The Catalog Name
* The Table Name
* The Field Name
* The Field Type
We can use this information to ask for the field information from the database
via the
[DatabaseMetaData|https://docs.oracle.com/javase/7/docs/api/java/sql/DatabaseMetaData.html]
object. We can then create INSERT or UPDATE statements based on the [list of
primary
keys|https://docs.oracle.com/javase/7/docs/api/java/sql/DatabaseMetaData.html#getPrimaryKeys(java.lang.String,%20java.lang.String,%20java.lang.String)]
in the table:
* If the value in the VectorSchemaRoot corresponding to the primary key is
NULL, insert that record into the database.
* If the value in the VectorSchemaRoot corresponding to the primary key is not
NULL, update the existing record in the database.
We can also perform the same data conversion in reverse based on the field
types queried from the database.
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)