5

我是 Java 编程新手,我正在搜索 Java 代码以在 PostgreSQL 中存储图像并检索图像。

在 PostgreSQL 中,我使用了 Bytea 数据类型。图像被存储。但是当我检索时,我得到了 NULL。我无法获取图像。

对此的任何示例或任何其他建议都会有所帮助。

4

2 回答 2

13

postgresql jdbc 文档的第 7 章处理存储二进制数据并使用图像(*.gif 文件)作为示例。您可能想阅读它。

将图像插入数据库(来自上面的链接)

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

从数据库读取图像(也来自上面的链接)

// 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();
于 2013-02-28T04:23:49.263 回答
0

浏览Java 数据库连接API,这里是一个如何连接到 postgres 数据库的示例。如果有任何疑问.. 跟进!!

于 2013-02-28T04:26:48.373 回答