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