[Pljava-dev] Possible to override default type mappings?

Eric Faulhaber ecf at goldencode.com
Mon Aug 7 00:51:20 UTC 2006


Hello,

In order to use a pre-existing Java library which works with specialized
implementations of the basic SQL types (varchar, int, etc.), I am trying
to override the default type mappings for these types to use our
specialized classes instead of java.lang.String, java.lang.Integer, etc.

Is this possible?  I keep getting an error:

test_db=# select indexOf('ABC', 'A');
ERROR:  No java type mapping installed for "test.character"

I have used SQLJ to install my jar with a deployment descriptor which
adds the type mappings and creates my "indexOf(varchar, varchar)" function:

      select sqlj.add_type_mapping('int', 'test.integer');
      select sqlj.add_type_mapping('varchar', 'test.character');

      create function indexOf(varchar, varchar) returns int
      as 'test.character.indexOf(test.character, test.character)'
      language java;

There are no errors at this stage and it looks as though the type
mappings were set up correctly:

      test_db=# select * from sqlj.typemap_entry;
       mapid |    javaname    |      sqlname
      -------+----------------+--------------------
          46 | test.integer   | pg_catalog.int4
          47 | test.character | pg_catalog.varchar

I also use sqlj.set_classpath to set my classpath to my installed jar,
which reports no error.

I am testing with PL/Java version 1.3.0 on SUSE Linux 10, PG 8.1.3
(though I will need to support this configuration with PG 8.1.4 on
multiple Linux distros).

Thanks in advance for any help.

Regards,
Eric Faulhaber




More information about the Pljava-dev mailing list