Получение метаданных Oracle ADT/User Type из JDBC

В ответ на этот вопрос о том, как получить/ написать Oracle Table Types из JDBC, возможно ли получить либо метаданные типа напрямую, либо просто имя типа (которое затем можно объединить с драйвером Oracle StructDescriptor для получения необходимых данных)?

В частности, с учетом этой процедуры:

CREATE OR REPLACE PROCEDURE andrew_test (
      p_in_num_param          IN NUMBER
    , p_in_char_param         IN VARCHAR2
    , p_in_date_param         IN DATE
    , p_in_adt_param          IN sw_ty_number_array
    , p_out_num_param         OUT NUMBER
    , p_out_char_param        OUT VARCHAR2
    , p_out_date_param        OUT DATE
    , p_out_adt_param         OUT sw_ty_number_array
    , p_inout_num_param    IN OUT NUMBER
    , p_inout_char_param   IN OUT VARCHAR2
    , p_inout_date_param   IN OUT DATE
    , p_inout_adt_param    IN OUT sw_ty_number_array
) AS
BEGIN
    NULL;
END;
/

И этот код Java (предположим, что ParameterMetadata — это просто POJO):

Connection conn = dataSource.getConnection();
DatabaseMetaData metadata = conn.getMetaData();
rs = metadata.getProcedureColumns(packageName, this.schemaName, procedureName, null);

while(rs.next()) {
    ProcedureParameter param = new ProcedureParameter(rs.getString("COLUMN_NAME"), rs.getInt("DATA_TYPE"), rs.getInt("COLUMN_TYPE"), rs.getString("TYPE_NAME"));
    System.out.println(param);
}

Получите что-то более значимое, чем идентификатор типа SQL 1111 ("Другое") и имя типа "TABLE" (предпочтительно sw_ty_number_array).

ProcedureParameter [parameterName=P_IN_NUM_PARAM, sqlType=3, parameterType=1, parameterTypeName=NUMBER]
ProcedureParameter [parameterName=P_IN_CHAR_PARAM, sqlType=12, parameterType=1, parameterTypeName=VARCHAR2]
ProcedureParameter [parameterName=P_IN_DATE_PARAM, sqlType=93, parameterType=1, parameterTypeName=DATE]
ProcedureParameter [parameterName=P_IN_ADT_PARAM, sqlType=1111, parameterType=1, parameterTypeName=TABLE]
ProcedureParameter [parameterName=P_OUT_NUM_PARAM, sqlType=3, parameterType=4, parameterTypeName=NUMBER]
ProcedureParameter [parameterName=P_OUT_CHAR_PARAM, sqlType=12, parameterType=4, parameterTypeName=VARCHAR2]
ProcedureParameter [parameterName=P_OUT_DATE_PARAM, sqlType=93, parameterType=4, parameterTypeName=DATE]
ProcedureParameter [parameterName=P_OUT_ADT_PARAM, sqlType=1111, parameterType=4, parameterTypeName=TABLE]
ProcedureParameter [parameterName=P_INOUT_NUM_PARAM, sqlType=3, parameterType=2, parameterTypeName=NUMBER]
ProcedureParameter [parameterName=P_INOUT_CHAR_PARAM, sqlType=12, parameterType=2, parameterTypeName=VARCHAR2]
ProcedureParameter [parameterName=P_INOUT_DATE_PARAM, sqlType=93, parameterType=2, parameterTypeName=DATE]
ProcedureParameter [parameterName=P_INOUT_ADT_PARAM, sqlType=1111, parameterType=2, parameterTypeName=TABLE]

person Andrew    schedule 19.04.2016    source источник


Ответы (1)


На данный момент нам не удалось найти работающее решение.

Текущая альтернатива — запросить представление user_arguments и получить данные вручную.

person Andrew    schedule 20.04.2016