[Pljava-dev] Calling pl/pgsql functions from pl/java?

Lucas Madar lucas at mcsnw.com
Tue Dec 11 01:29:06 UTC 2007


Hello,

I'm trying to call preexisting plpgsql functions from pljava. I've been 
beating my head against a wall with them all day, and I can't seem to 
figure out what I'm doing wrong. Apologies if this is too much junk, but 
this is a low-traffic list ;)

Thanks,
Lucas Madar



Given the following setup, why does this happen? I can't seem to call 
*any* plpgsql functions from within pl/java.

create or replace function pljava_test_internal(integer) returns varchar 
as 'stupid.test.Dummy.test_internal' LANGUAGE 'javaU' VOLATILE;
create or replace function pljava_test_external(integer) returns varchar 
as 'stupid.test.Dummy.test_external' LANGUAGE 'javaU' VOLATILE;

CREATE OR REPLACE FUNCTION plpgsql_test_external(varchar) RETURNS 
varchar AS $$
BEGIN
   return $1 || ' from plpgsql!';
END;
$$ LANGUAGE plpgsql VOLATILE;

package stupid.test;
import java.sql.*;
public class Dummy {

        public static String test_internal(int number) {
                return "internal test la la la " + number;
        }

        public static String test_external(int number) throws SQLException {
                String text = "internal test la la la " + number;
                Connection sql = 
DriverManager.getConnection("jdbc:default:connection");
                String ret;

                Statement stmt = sql.createStatement();
                if(stmt.execute("SELECT plpgsql_test_external('" + text 
+ "');"))
                        throw new SQLException("No results from query?");
                ResultSet res = stmt.getResultSet();
                ret = res.getString(1);
                res.close();
                stmt.close();
                sql.close();

                return ret;
        }
}


# select pljava_test_internal(1);
   pljava_test_internal
--------------------------
 internal test la la la 1
(1 row)

# select plpgsql_test_external('test');
 plpgsql_test_external
-----------------------
 test from plpgsql!
(1 row)

# select pljava_test_external(1);
ERROR:  java.sql.SQLException: ResultSet is not positioned on a valid row




More information about the Pljava-dev mailing list