Bild in Datenbank speichern

Status
Nicht offen für weitere Antworten.
U

Unbekannt

Gast
Hi Leute
Hab ein Problem. Ich soll Bilder in einer Datenbank speichern. Hinterher soll ich die Bilder aus der Datenbank wieder auslesen und auf einem Fenster ausgeben. Das funktioniert jedoch nicht.

PreparedStatement ps = con.prepareStatement(q);
ps.setBinaryStream(1, new FileInputStream(f), (int) new File(f).length());
ps.executeUpdate();
ps.close();

Statement stmt = con.createStatement();
ResultSet rset = stmt.executeQuery(s);
byte[] picBytes = rset.getBytes(1);
ImageIcon image = new ImageIcon(picBytes);
img = image.getImage();
stmt.close();

Wie kann ich das Bild dann ausgeben?

Danke schon mal im vorraus.
 
U

Unbekannt

Gast
Das ist das komplette Programm:

import java.awt.*;
import java.awt.event.*;
import java.sql.*;
import java.io.*;
import javax.swing.ImageIcon;

public class test7 extends Frame {
Connection con;

Image img;

public test7() {
super();
}

public test7(String title) {
super(title);
init();
}

public void init() {
submitImageSQL(
"INSERT INTO Bildpfad1 VALUES(?)",
"C:\\bulb2.gif");
addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent evt) {
System.exit(0);
}
});
setBackground(Color.darkGray);
setSize(200, 200);
setVisible(true);
}

public void paint(Graphics g) {
try {
Image img = submitImageSQL("SELECT * FROM Bildpfad1");
g.drawImage(img, getHeight() / 2, getWidth() / 2, this);

} catch (Exception e) {
System.out.println("Fehler 2");
}
}

public static void main(String[] args) {
new test7("test 7");
}

private void Kontakt() {
try {
Class.forName("org.hsqldb.jdbcDriver");
con = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost/",
"SA", "");
} catch (Exception e) {

}
}

public void submitImageSQL(String q, String f) {
try {
Kontakt();
PreparedStatement ps = con.prepareStatement(q);
ps.setBinaryStream(1, new FileInputStream(f), (int) new File(f)
.length());
ps.executeUpdate();
ps.close();
} catch (Exception e) {
System.out.println("Fehler");
}
}

public Image submitImageSQL(String s) throws Exception {
Kontakt();
Statement stmt = con.createStatement();
ResultSet rset = stmt.executeQuery(s);
byte[] picBytes = rset.getBytes("Pfad");
ImageIcon image = new ImageIcon(picBytes);
img = image.getImage();
stmt.close();
return img;
}
}
 
U

Unbekannt

Gast
Jetzt tritt plötzlich ein Fehler in folgender Zeile auf:

byte[] picBytes = rset.getBytes("Pfad");
 

Bleiglanz

Gesperrter Benutzer
Code:
 catch (Exception e) {

}

das ist MIST

schreib wenigstens ein e.printStackTrace() rein
 
U

Unbekannt

Gast
So lautet der Fehler:

java.sql.SQLException: No data is available
at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
at org.hsqldb.jdbc.Util.sqlException(Unknown Source)
at org.hsqldb.jdbc.jdbcResultSet.checkAvailable(Unknown Source)
at org.hsqldb.jdbc.jdbcResultSet.getObject(Unknown Source)
at org.hsqldb.jdbc.jdbcResultSet.getBytes(Unknown Source)
at test7.test7.submitImageSQL(test7.java:83)
at test7.test7.init(test7.java:33)
at test7.test7.<init>(test7.java:20)
at test7.test7.main(test7.java:53)
 
U

Unbekannt

Gast
In der Datenbank steht dann komischerweise aber der Pfad nicht sondern lauter Zaheln und Buchstaben.
 
U

Unbekannt

Gast
In der Datenbank steht dann

47494638396128002800c20000fffffff

usw. drin
 
U

Unbekannt

Gast
Wie müsste denn die Datenbank angelegt werden, damit sie Bilder speichert? Und wie schickt man dann die Bilder hin? Ich hab das Gefühl, dass die Bilder nicht mal richtig in der Datenbank gespeichert werden.
 
U

Unbekannt

Gast
Also ich habe jetzt eine Datenbaktabelle mit folgendem Befehl erzeugt:
CREATE TABLE dataobject
(
id INTEGER NOT NULL,
data BINARY,
PRIMARY KEY(id)
);

Danach musste ich ein wenig am Quelltext ändern:

PreparedStatement pstmt = conn.prepareStatement(
"INSERT INTO dataobject VALUES (1, ?);");
pstmt.setBytes(1, "C:\\bulb2.gif");
pstmt.execute();

Statement stm = conn.createStatement();
ResultSet rs = stm.executeQuery(
"SELECT data from dataobject where id = 1;");
rs.next();
imageDataByteArray = rs.getBytes(1);

Aber jetzt kommen nicht einmal mehr Daten in der Datenbank an.

Beim folgenden Link hab ich die Sachen gefunden.
http://www.myjavaserver.com/exec/.ado5GtpKLwzNf2CZvwBFfNjLDwyZnxzT9vB1j3BM1JBPfwBMuwBVHwp0f2y
 

Bleiglanz

Gesperrter Benutzer
pstmt.setBytes(1, "C:\\bulb2.gif");

völliger Unsinn!

pstmt.setBytes(1, imageDataByteArray); // da muss ein bytearray her

nur zu deiner Info:

es gibt keine Magie, die dir aus dem C:\\bulb.gif automatisch ein byte[] machen kann
 
U

Unbekannt

Gast
Ich hatte in den Zeilen davor folgendes geschrieben:
byte[] Byte = null;
String str = "C:\\bulb2.gif";
int i = str.length();
char[] c = str.toCharArray();
while (i > 0) {
Byte += c;
i--;
}

Aber trotzdem funktioniert es nicht. Hab ich da irgend etwas falsch gemacht?
 
U

Unbekannt

Gast
Für die folgende Zeile bekomme ich eine Fehlermeldung:

Byte += c;

java.lang.NullPointerException
at test7.test7.submitImageSQL(test7.java:83)
at test7.test7.init(test7.java:25)
at test7.test7.<init>(test7.java:21)
at test7.test7.main(test7.java:56)

Hab ich da irgend etwas falsch gemacht?
 
U

Unbekannt

Gast
Ich verarsch dich nicht. Die Fehler sind tatsächlich da. Hab nur noch nicht so viel Erfahrung mit Java.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Bild in einer Datenbank speichern? AWT, Swing, JavaFX & SWT 7
G Bild direkt aus Datenbank anzeigen lassen AWT, Swing, JavaFX & SWT 14
M JavaFX Mandelbrot-bild noch nicht optimiert AWT, Swing, JavaFX & SWT 7
berserkerdq2 Wie füge ich ein Bild in javafx mit dem Scenebuilder ein, das automatisch mitgezogen wird, wenn das Fenster vergrößert wird oder Vollbildmodus AWT, Swing, JavaFX & SWT 6
frager2345 Bild aus Dateien lesen und als Hintergrund verwenden AWT, Swing, JavaFX & SWT 2
T Bild in ein graphics füllen AWT, Swing, JavaFX & SWT 2
N imageIcon zeigt kein Bild an AWT, Swing, JavaFX & SWT 5
B Bild lädt nicht AWT, Swing, JavaFX & SWT 2
izoards Bild ausdrucken - PageFormat setzen geht nicht AWT, Swing, JavaFX & SWT 5
M Bild wird nicht geladen obwohl sie gefunden wird AWT, Swing, JavaFX & SWT 0
V JavaFX Bild leer und keine Fehlermeldung AWT, Swing, JavaFX & SWT 21
D JavaFX Bearbeitetes Bild wird nicht gespeichert AWT, Swing, JavaFX & SWT 9
D JavaFX Größe des Bild an ImageView anpassen AWT, Swing, JavaFX & SWT 3
M Bewegtes Bild im BorderLayout.CENTER AWT, Swing, JavaFX & SWT 6
C Falschfarbenbild (lineare Grauwertspreizung)aus Grauwert-Bild erstellen AWT, Swing, JavaFX & SWT 15
C Kleineres Bild an bestimmte Koordinaten setzen AWT, Swing, JavaFX & SWT 6
S Bild neu skalieren - Bild in Bild speichern? AWT, Swing, JavaFX & SWT 6
N Bild Drehen AWT, Swing, JavaFX & SWT 1
Hatsi09 Swing JPanel Bild einfügen AWT, Swing, JavaFX & SWT 14
J Bild von anderer Klasse will nicht laden AWT, Swing, JavaFX & SWT 1
M JavaFX Bild zur ImageView in einem Kreis anzeigen. AWT, Swing, JavaFX & SWT 4
T JFrame Bild einfügen AWT, Swing, JavaFX & SWT 9
M Combobox bild anklicken AWT, Swing, JavaFX & SWT 2
cool_brivk24 Swing ImageIcon lädt kein Bild AWT, Swing, JavaFX & SWT 12
L Bild nicht in der Mitte AWT, Swing, JavaFX & SWT 16
B JavaFX Bild um die eigene Achse drehen lassen AWT, Swing, JavaFX & SWT 0
J Swing Bild in Button AWT, Swing, JavaFX & SWT 11
I Bild über FXML (ImageView, Image) anzeigen AWT, Swing, JavaFX & SWT 1
T Image Loader lädt Bild nicht AWT, Swing, JavaFX & SWT 10
stroggi Swing Mehrere transparentes Objekte (Grafiken) über einem Bild (JLabel) darstellen AWT, Swing, JavaFX & SWT 4
P Kein Bild wird angezeigt bei ImageIcon AWT, Swing, JavaFX & SWT 16
T JavaFX Bild in Tabellenzelle AWT, Swing, JavaFX & SWT 2
Ksanatos Swing Bild (.jpg) einlesen und per Button wechseln AWT, Swing, JavaFX & SWT 9
S JPanel rotieren, Bild ist abgeschnitten, Clipping? AWT, Swing, JavaFX & SWT 0
MaxG. Swing Bild Button AWT, Swing, JavaFX & SWT 7
P Swing Bild Skallieren AWT, Swing, JavaFX & SWT 1
P Jframe Bild einfügen, Hintergrund Farbe ändern, und Button schrift Größe ändern AWT, Swing, JavaFX & SWT 2
A Swing Bild wird nicht mehr geladen AWT, Swing, JavaFX & SWT 4
A Swing Gemaltes Bild über saveDialog speichern unter AWT, Swing, JavaFX & SWT 15
R 2D-Grafik PNG Bild per Graphics auf JPanel AWT, Swing, JavaFX & SWT 9
S Bild mit ImageIcon auf GUI verkleinern AWT, Swing, JavaFX & SWT 3
T AWT Farben in einem Bild ändern AWT, Swing, JavaFX & SWT 8
I JFrame Bild strecken und auf Bildschirmgröße anpassen AWT, Swing, JavaFX & SWT 2
F Gezeichnetes als bild speichern AWT, Swing, JavaFX & SWT 4
B 2D-Grafik Bild farblich filtern AWT, Swing, JavaFX & SWT 2
B JavaFX ImageView neues Bild zuweisen AWT, Swing, JavaFX & SWT 19
A 2D-Grafik Bild wird nicht neu gezeichnet AWT, Swing, JavaFX & SWT 24
K Bild in JFrame AWT, Swing, JavaFX & SWT 2
S JavaFX Teil eines Bildes ausschneiden / als neues Bild nutzen AWT, Swing, JavaFX & SWT 8
B Swing Unterteiltes JFrame mit Bild in der Mitte AWT, Swing, JavaFX & SWT 4
I Applet BlueJ Applet - Bild mit if-Schleife zeichnen lassen AWT, Swing, JavaFX & SWT 16
Z Bildervorschau, MouseDragged das Bild verschieben AWT, Swing, JavaFX & SWT 1
M JavaFX Ein Bild ohne Rahmen fällt runter? AWT, Swing, JavaFX & SWT 2
G Anonyme Instanz von JXImageView erstellen und mit Bild initialisieren AWT, Swing, JavaFX & SWT 7
A JPanel Bild laden (Porblem mit Dateipfad) AWT, Swing, JavaFX & SWT 2
M JavaFX - Bild in Jar einbinden, sodass es auch außerhalb der IDE geladen wird. AWT, Swing, JavaFX & SWT 2
M Bild Beschreibung mit ImageIO speichern AWT, Swing, JavaFX & SWT 1
M "ImageIO.read()" liest Bild nicht richtig ein AWT, Swing, JavaFX & SWT 3
I Swing JLabel Bild für 1sec anzeigen lassen AWT, Swing, JavaFX & SWT 13
K Bild in Label wird nicht angezeigt AWT, Swing, JavaFX & SWT 5
C GUI öfters durchlaufen und hinterher Bild speichern AWT, Swing, JavaFX & SWT 1
M AWT Farben in Bild ersetzen AWT, Swing, JavaFX & SWT 11
E JavaFX Bild einfügen AWT, Swing, JavaFX & SWT 6
G paintComponents zerstückelt Bild AWT, Swing, JavaFX & SWT 0
C 2D Grafik ein Bild soll permanent durchlaufen AWT, Swing, JavaFX & SWT 2
1 Textfield: jede Buchstabe ein Bild AWT, Swing, JavaFX & SWT 2
C Bild Koordinaten AWT, Swing, JavaFX & SWT 6
M Bild aus JLabel resizen und speichern AWT, Swing, JavaFX & SWT 0
M Bild in JPanel mit Maus einfügen AWT, Swing, JavaFX & SWT 0
B JPanel und png-Bild AWT, Swing, JavaFX & SWT 2
B Swing Bild von Webseite herunterladen, diese dann in JList anzeigen. AWT, Swing, JavaFX & SWT 1
O 2D-Grafik Bild abgeschnitten nach Rotation mit Affine Transform und Hintergrund Schwarz AWT, Swing, JavaFX & SWT 8
A Swing Malprogramm Bild speichern? AWT, Swing, JavaFX & SWT 9
U Bild innerhalb hatml code anzeigen AWT, Swing, JavaFX & SWT 5
Y JavaFX Bild speichern und Pfad dazu abspeichern AWT, Swing, JavaFX & SWT 2
S Geladenes Bild wird nicht in JPanel angezeigt AWT, Swing, JavaFX & SWT 7
L 2D-Grafik Bild in Richtung Maus drehen AWT, Swing, JavaFX & SWT 18
C Bild in JFrame AWT, Swing, JavaFX & SWT 8
T AWT Bild laden und transparent zeichnen AWT, Swing, JavaFX & SWT 2
I SWT Bilder, bzw. ein einzelnes Bild AWT, Swing, JavaFX & SWT 6
L JavaFX: Bild in Image einlesen AWT, Swing, JavaFX & SWT 11
T Mit getSubimage ruckelt das Bild AWT, Swing, JavaFX & SWT 7
T Bild drehen ohne Resize AWT, Swing, JavaFX & SWT 3
A Bild in JLabel skalieren AWT, Swing, JavaFX & SWT 4
A Bild über Imageviewer auf GUI anzeigen AWT, Swing, JavaFX & SWT 3
D 3D-Grafik [JOGL] streifen im bild AWT, Swing, JavaFX & SWT 2
D Bild bewegen mit Tastendruck AWT, Swing, JavaFX & SWT 7
H Bild wird nicht angezeigt, Fehlercode unverständlich AWT, Swing, JavaFX & SWT 5
J 2D-Grafik Bildteile in ein anderes Bild speichern AWT, Swing, JavaFX & SWT 12
C Swing ImageIcon mit Bild aus Temp-Verzeichniss füllen AWT, Swing, JavaFX & SWT 15
J Swing Bild laden, Kreise drin malen, Schreiben AWT, Swing, JavaFX & SWT 2
S Bild skalieren AWT, Swing, JavaFX & SWT 3
D Bild in JFrame nur kurz da AWT, Swing, JavaFX & SWT 9
H Bild mit KeyListener verschieben AWT, Swing, JavaFX & SWT 2
GianaSisters Bild wird S/W gespeichert. AWT, Swing, JavaFX & SWT 4
O Bild auf das JLabel AWT, Swing, JavaFX & SWT 10
D Swing Text auf Bild legen AWT, Swing, JavaFX & SWT 7
S Ein externes Bild in ein JFrame einfügen AWT, Swing, JavaFX & SWT 8
J Swing Bild wird nicht auf JLabel angezeigt AWT, Swing, JavaFX & SWT 12
S Swing Bild auf jPanel nach Änderung von JComboBox zeichnen AWT, Swing, JavaFX & SWT 4

Ähnliche Java Themen

Neue Themen


Oben