postgresql mit jdbc und gespeicherten Prozeduren (Funktionen): ResultSet

Ich habe gerade versucht, eine gespeicherte Funktion vom Server (getStat) aufzurufen, die so aussieht:

create type stat as (type text, location text, number int);
create function getStat() returns setof stat as 'select distinct table1.type, table1.location, table1.number from table1, table2 where table2.finding=10 order by number desc;' language 'sql';

Hier ist der JDBC-Code:

CallableStatement callable = null;

    String storedProc = "{call getStat(?, ?, ?)}";

    try {
        callable = connection.prepareCall(storedProc);

        callable.registerOutParameter(1, java.sql.Types.VARCHAR);
        callable.registerOutParameter(2, java.sql.Types.VARCHAR);
        callable.registerOutParameter(3, java.sql.Types.INTEGER);

        boolean results = callable.execute();

        System.out.println(callable.getString(1));
        System.out.println(callable.getString(2));
        System.out.println(callable.getInt(3));

        while(results){
            ResultSet rs = callable.getResultSet();
            while(rs.next()){
                System.out.println(rs.getString(1));
                System.out.println(rs.getString(2));
                System.out.println(rs.getInt(3));
            }
            //rs.close();

            results = callable.getMoreResults();
        }

Okay, und jetzt das Problem: Wenn ich es anrufe, druckt es nur die erste Zeile der gesamten Masse aus, die gedruckt werden soll. Ja, das ist klar, denn ich führe folgenden Code aus:

            System.out.println(callable.getString(1));
            System.out.println(callable.getString(2));
            System.out.println(callable.getInt(3));

Aber ich mache dasselbe in der while-Schleife ... und es wird nichts mehr angezeigt.

Vielleicht liegt das Problem auf der Hand, aber das fehlt mir :(

Vielen Dank!

Antworten auf die Frage(1)

Ihre Antwort auf die Frage