Store and retrieve images in Postgresql using Java [closed]

独自空忆成欢 提交于 2019-11-26 23:19:40

问题


I am new to Java programming, I am searching for Java code to store images in PostgreSQL and to retrieve the image.

In PostgreSQL I have used Bytea Data-type. the image was stored. but when I retrieve I am getting NULL. I cant get the image.

Any example for this or any other suggestion on this would be helpful.


回答1:


chapter 7 of the postgresql jdbc documentation deals with storing binary data and uses an image (*.gif file) an an example. you might want to read it.

inserting an image into the db (from the link above)

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

reading an image from the db (also from the link above)

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



回答2:


Go throught the Java Database Connectivity API and here is an example of how to connect to postgres database. If any doubts.. follow up!!



来源:https://stackoverflow.com/questions/15127100/store-and-retrieve-images-in-postgresql-using-java

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!