Configurar tu aplicación OpenXava contra PostgreSQL es muy fácil, básicamente has de añadir una dependencia al controlador JDBC para PostgreSQL en tu proyecto y definir correctamente la base de datos. No necesitas tocar el código de tu aplicación.
Asumimos que ya tienes el PostgreSQL instalado y funcionando.
Añadir controlador JDBC para PostgreSQL en el proyecto
Edita el archivo pom.xml en la raíz de tu proyecto, allí añade la siguiente dependencia dentro de la parte <dependencies>:
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>42.7.3</version>
</dependency>
Quizás ya tengas este código en tu
pom.xml pero comentado, en ese caso simplemente descoméntalo.
Ajustar la definición de la fuente de datos
Edita src/main/webapp/META-INF/context.xml de tu proyecto y ajusta la definición de tu fuente de datos para que apunte a PostgreSQL, algo así:
<Resource name="jdbc/MiAplicacionDS" auth="Container"
type="javax.sql.DataSource"
maxTotal="100" maxIdle="20" maxWaitMillis="10000"
username="root" password="ao49fmsk"
driverClassName="org.postgresql.Driver"
url="jdbc:postgresql://localhost:5432/miaplicaciondb"/>
La diferencia está en driverClassName y url. La parte final de la url, miaplicaciondb en este ejemplo, es el nombre de tu base de datos PostgreSQL. Obviamente, en lugar de localhost deberías poner la dirección del servidor que alberga PostgreSQL. También pon el username y password correctos. Puede que el código de arriba ya esté en tu context.xml pero comentado, en ese caso simplemente descoméntalo. No olvides comentar o quitar la fuente de datos para HSQLDB (incluida por defecto al crear un nuevo proyecto OpenXava), sólo una fuente de datos (con el mismo nombre) debería estar activa.
Crear manualmente el esquema
La versión 5.6 de Hibernate tiene un bug que no crea ya automáticamente el esquema, por lo que las tablas tampoco. Si te encuentras con este error, la solución es crear manualmente el esquema en la base de datos ejecutando la sentencia:
CREATE SCHEMA miaplicaciondb;
Así las tablas se crearán una vez que se inicie la aplicación.
Reconstruir proyecto
Después de los cambios has de reconstruir (rebuild) tu proyecto. En OpenXava Studio pulsa con el botón derecho del ratón en tu proyecto y escoge Run As > Maven install, así:
O si tienes Maven instalado en tu ordenador y prefieres usar la línea de órdenes:
$ cd miaplicacion
$ mvn install
Nota de optimización: En lugar de mvn install, que hace un build de Maven completo, puedes usar mvn war:exploded, suficiente para aplicar los cambios de arriba para desarrollo. Puedes llamar a mvn war:exploded desde el OpenXava Studio con Run As > Maven build... y tecleando war:exploded para goal.
Ejecutar aplicacion
Ejecuta tu aplicación, debería funcionar bien contra tu base de datos PostgreSQL. Si fallara, verifica que tu base de datos está funcionando, que el usuario y la contraseña son correctos, que la IP del servidor es correcta. Verifica también que el usuario tiene privilegios para crear bases de datos y tablas (si quieres usar la generación automática de esquema de OpenXava, no necesario si las tablas ya existen).
Si sigue fallando pregúntanos en el foro de ayuda de OpenXava. Incluye el contenido de tu persistence.xml, context.xml (quita las contraseñas) y sobre todo la traza generada, puedes encontrar la traza en la pestaña Console del OpenXava Studio.