una tipo postgres para insertar imagenes imagen guardar desde datos dato como java image postgresql bytea

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();