Oracle RAW ID y columnas JDBC

Estoy tratando de desarrollar un servlet de Java simple que llame a una base de datos Oracle 11g XE. La base de datos que me proporcionaron utiliza tipos de columna RAW para los ID en todas las tablas.

Inicialmente, traté de recuperar los datos de JDBC y base64 codificaba las matrices de bytes VARBINARY que se estaban devolviendo para poder pasar los resultados a través de JSON al sistema front-end. Sin embargo, después de descodificar base64 y de intentar volver a establecer la matriz de bytes en la columna, Oracle / JDBC no estaba devolviendo datos.

Decidí probar y hacer que Oracle realice la codificación / decodificación y pude obtener las siguientes consultas para disparar en Oracle usando SQL Developer 2.

SELECT utl_encode.base64_encode(IDCOLUMN), FIRST_NAME FROM TABLENAME
SELECT utl_encode.base64_encode(IDCOLUMN), FIRST_NAME FROM TABLENAME WHERE IDCOLUMN = utl_encode.base64_decode('BASE64STRING')

Sin embargo, al ejecutar estas colas usando JDBC:

conn = isConnSupplied ? userConn : ResourceManager.getConnection();
Statement stmt = conn.createStatement();
 try {
   ResultSet rset = stmt.executeQuery("SELECT utl_encode.base64_encode(IDCOLUMN), FIRST_NAME FROM TABLENAME");
   try {
     while (rset.next())
       System.out.println (rset.getString(1));   // Print col 1
   } 
   finally {
      try { rset.close(); } catch (Exception ignore) {}
   }
 } 
 finally {
   try { stmt.close(); } catch (Exception ignore) {}
 }

Obtuve el siguiente error:

java.sql.SQLException: ORA-29261: bad argument
ORA-06512: at "SYS.UTL_ENCODE", line 8
ORA-06512: at "SYS.UTL_ENCODE", line 243

oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:445)
oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:396)
oracle.jdbc.driver.T4C8Oall.processError(T4C8Oall.java:879)
oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:450)
oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:192)
oracle.jdbc.driver.T4C8Oall.doOALL(T4C8Oall.java:531)
oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:193)
oracle.jdbc.driver.T4CStatement.executeForDescribe(T4CStatement.java:866)
oracle.jdbc.driver.OracleStatement.executeMaybeDescribe(OracleStatement.java:1167)
oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1289)
oracle.jdbc.driver.OracleStatement.executeQuery(OracleStatement.java:1491)
oracle.jdbc.driver.OracleStatementWrapper.executeQuery(OracleStatementWrapper.java:406)
com.pearson.familyportal.servlet.WebController.doPost(WebController.java:97)
com.pearson.familyportal.servlet.WebController.doGet(WebController.java:171)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

Pregunta: ¿Cuál es la mejor manera de lidiar con las matrices de bytes de la columna de ID RAW cuando tengo que pasar esto por el lado del cliente? Si permito que Oracle haga la conversión, ¿qué estoy haciendo mal que a JDBC no le gusta?

Gracias por adelantado.