2011-10-24 12 views
5

Non ho problemi a passare numeri e stringhe avanti e indietro da PL/SQL a Java, ma come faccio a passare gli array? Sto chiamando Java da PL/SQL - non da un'altra parte.Come restituire un array da Java a PL/SQL?

Di seguito è un esempio in cui get_widgets_as_string funziona come previsto. Come posso scrivere una specifica di chiamata per PL/SQL per so19j.get_widgets_as_array() in modo da poterla chiamare da PL/SQL?

Ho letto Publishing Java Classes With Call Specifications dove posso vedere che la tabella nidificata corrisponde a oracle.sql.ARRAY, ma non riesco a farlo funzionare. Probabilmente mi mancano alcuni dettagli banali perché non sono un programmatore 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; 
/

risposta

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; 
/

Stampe:

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

PL/SQL procedure successfully completed. 

Vedi anche: How to create an oracle.sql.ARRAY object?

0

Non so circa la cosa pl/sql ma che u può fare è elaborare il risultato da PL/SQL e inserire il risultato in un metodo set e poi u può ottenerlo.

+1

Mi dispiace, ma sto fissando questa risposta in totale incomprensione. Per me è solo un gobbledygook. Vorresti (o qualcun altro) piacere ad elaborare un po 'di più? – user272735

Problemi correlati