2011-10-24 13 views
5

No tengo problemas para pasar números y cadenas de PL/SQL a Java, pero ¿cómo paso matrices? Estoy llamando a Java desde PL/SQL, y no a la inversa.¿Cómo devolver una matriz de Java a PL/SQL?

A continuación se muestra un ejemplo en el que get_widgets_as_string funciona como se esperaba. ¿Cómo escribo una especificación de llamada PL/SQL para so19j.get_widgets_as_array() para que pueda llamarla desde PL/SQL?

He leído Publishing Java Classes With Call Specifications donde puedo ver que la tabla anidada corresponde a oracle.sql.ARRAY, pero no puedo hacer que funcione. Probablemente me faltan detalles triviales porque no soy un programador de Java.

create or replace and compile java source named "so19j" as 

import java.lang.*; 

public class so19j { 
    public static String get_widgets_as_string() { 
     String widgets = "foo;bar;zoo"; 
     return widgets; 
    } 

    public static String[] get_widgets_as_array() { 
     String[] widgets = new String[]{"foo", "bar", "zoo"}; 
     return widgets; 
    } 
}; 
/
show errors java source "so19j" 

create or replace function get_widgets_as_string return varchar2 as 
language java name 'so19j.get_widgets_as_string() return java.lang.String'; 
/
show errors 

declare 
    widgets constant varchar2(32767) := get_widgets_as_string; 
begin 
    dbms_output.put_line('widgets = ' || widgets); 
end; 
/

/* How to write a call specification for so19j.get_widgets_as_array so that it 
can be excercised by the PL/SQL block below ? */ 

declare 
    type widgets_t is table of varchar2(32767); 
    widgets constant widgets_t := get_widgets_as_array; 
begin 
    for i in widgets.first .. widgets.last loop 
    dbms_output.put_line('widgets(' || i || ') = ' || widgets(i)); 
    end loop; 
end; 
/

Respuesta

2
/* The type has to be SQL type so that it is also visible for Java. */ 
create or replace type widgets_t is table of varchar2(32767); 
/

create or replace and compile java source named "so19ja" as 
import java.lang.*; 
public class so19ja { 
    public static String[] get_widgets_as_array() { 
     String[] widgets = new String[]{"foo", "bar", "zoo"}; 
     return widgets; 
    } 

    public static java.sql.Array array_wrapper(
     String typeName, 
     Object elements 
    ) throws java.sql.SQLException { 
     oracle.jdbc.OracleDriver ora = new oracle.jdbc.OracleDriver(); 
     java.sql.Connection conn = ora.defaultConnection(); 
     oracle.jdbc.OracleConnection oraConn = 
      (oracle.jdbc.OracleConnection)conn; 
     /* Yeah - typeName have to be UPPERCASE, really. */ 
     java.sql.Array arr = 
      oraConn.createARRAY(typeName.toUpperCase(), elements); 
     return arr; 
    } 

    public static java.sql.Array get_widgets_as_array_wrapped() 
    throws java.sql.SQLException { 
     return array_wrapper("widgets_t", get_widgets_as_array()); 
    } 
}; 
/
show errors java source "so19ja" 

create or replace function get_widgets_as_array return widgets_t as 
language java name 'so19ja.get_widgets_as_array_wrapped() return java.sql.Array'; 
/
show errors 

declare 
    widgets constant widgets_t := get_widgets_as_array; 
begin 
    for i in widgets.first .. widgets.last loop 
    dbms_output.put_line('widgets(' || i || ') = ' || widgets(i)); 
    end loop; 
end; 
/

Lienzo:

widgets(1) = foo 
widgets(2) = bar 
widgets(3) = zoo 

PL/SQL procedure successfully completed. 

Ver también: How to create an oracle.sql.ARRAY object?

0

No sé sobre lo PL/SQL, pero lo que u puede hacer es procesar el resultado de PL/SQL e insertar el resultado en un método set y luego más tarde u puede conseguirlo.

+1

Lo siento, pero estoy mirando esta respuesta en total incomprensión. Para mí es solo un charlatán. ¿Le gustaría (u otra persona) elaborar un poco más? – user272735

Cuestiones relacionadas