5

私はJavaプログラミングに不慣れで、PostgreSQLに画像を保存し、画像を取得するためのJavaコードを探しています。

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

dbから(上記のリンクからも)画像を読み取る

// 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 Database Connectivity APIを確認してください。これは、postgresデータベースに接続する方法の例です疑問がある場合は..フォローアップ!!

于 2013-02-28T04:26:48.373 に答える