Pues he estado probando postgresql desde que salió la versión 9.0 beta1, y el no saber qué pasará con MySQL, en fin, eso es otra historia. El chiste es que hoy, bueno desde ayer, me topé con algo que me hacia considerar regresar a MySQL, aunque sé que en MySQL no es cualquier cosa hacerlo. Estoy guardando en la base de datos unas imágenes, y aquí van a empezar a polemizar en cuanto a si es mejor o no guardar datos binarios en la BD, pero una rápida respuesta a sus interrogantes es que pienso poner mi aplicación en clúster, por lo que me es más fácil si esos recursos se encuentran en la BD, no me importa tanto el rendimiento. En fin, intenté hacer eso, porque no funcionó, llegué al punto de intentarlo en una aplicación vacía con HSQLDB, y que funciona... charros, entonces es Postgresql, seguí debugueando y encontré el problema, resulta que en Postgresql 9.0 (ya estoy en el beta2, por bajar el beta3), cambiaron una opción que en versiones anteriores estaba de otra forma, la regresé a como se maneja en la version anterior y listo, funcionó. La opción se llama bytea_output y su valor por defecto, ahora, es 'hex', y la necesitamos en 'escape'. Este valor se puede cambiar de dos formas una es editando el postgresql.conf de la base de datos creada, buscando este valor dentro del archivo y cambiándolo y la otra es hacerlo directamente en la base de datos con la siguiente instrucción
Esto lo encontre en postgresonline
Bueno y cómo se hace? Pues utilizando la documentación de grails y del buen Tomás Lin
Dominio que va a aceptar el binario
GSP para captura de imagen (archivo binario)
Controlador que guarda el archivo
Y para ver la imagen, en el controlador ponemos una accion
ALTER DATABASE gisdb SET bytea_output='escape';
Esto lo encontre en postgresonline
Bueno y cómo se hace? Pues utilizando la documentación de grails y del buen Tomás Lin
Dominio que va a aceptar el binario
GSP para captura de imagen (archivo binario)
Controlador que guarda el archivo
Y para ver la imagen, en el controlador ponemos una accion
Comentarios