tipo - login java postgresql
Almacenar y recuperar imágenes en Postgresql usando Java (2)
Vaya a través de la API de conectividad a la base de datos Java y aquí hay un ejemplo de cómo conectarse a la base de datos postgres. Si hay dudas, ¡sigue!
Soy nuevo en la programación Java, estoy buscando código Java para almacenar imágenes en PostgreSQL y recuperar la imagen.
En PostgreSQL he usado Bytea Data-type. la imagen fue almacenada pero cuando recupero me estoy poniendo NULO. No puedo obtener la imagen.
Cualquier ejemplo para esto o cualquier otra sugerencia sobre esto sería útil.
El capítulo 7 de la documentación jdbc postgresql trata sobre el almacenamiento de datos binarios y utiliza una imagen (archivo * .gif) y un ejemplo. es posible que desee leerlo.
insertar una imagen en el db (desde el enlace de arriba)
File file = new File("myimage.gif");
FileInputStream fis = new FileInputStream(file);
PreparedStatement ps = conn.prepareStatement("INSERT INTO images VALUES (?, ?)");
ps.setString(1, file.getName());
ps.setBinaryStream(2, fis, (int)file.length());
ps.executeUpdate();
ps.close();
fis.close();
leyendo una imagen del db (también desde el enlace de arriba)
// Get the Large Object Manager to perform operations with
LargeObjectManager lobj = ((org.postgresql.PGConnection)conn).getLargeObjectAPI();
PreparedStatement ps = conn.prepareStatement("SELECT imgoid FROM imageslo WHERE imgname = ?");
ps.setString(1, "myimage.gif");
ResultSet rs = ps.executeQuery();
while (rs.next()) {
// Open the large object for reading
int oid = rs.getInt(1);
LargeObject obj = lobj.open(oid, LargeObjectManager.READ);
// Read the data
byte buf[] = new byte[obj.size()];
obj.read(buf, 0, obj.size());
// Do something with the data read here
// Close the object
obj.close();
}
rs.close();
ps.close();