Hallo,
ich bin mir nicht sicher ob es in diesen Bereich des Forums gehört oder doch eher in den der Datenbank.
Ich möchte meiner GUI eine Tabellen hinzufügen.Leider reicht dafür das Standarttablemodel nicht aus da ich auch Checkboxen in einer Spalte haben möchte. Also habe ich mir eine neues Modell erstellt und befülle es direkt mit den Infos aus der Datenbank. Mein Problem ist nun das ich direkt schon beim erstellen der Spaltennamen einen Unknown Source Fehler bekomme als ich versuche vom ResulSet meine Spaltennamen zu lesen.
Das neue Tabellenmodel
Der Fehler tritt bein Initialisieren des Arrays Spaltennamen auf. Meine Frage hierzu ist nun ob es überhaupt möglich ist auf diese Weise die Tabelle zu füllen oder ob es einen besseren Weg gibt, den ich nur noch nicht gefunden habe?
der Vollständigkeit halber hier noch die Entstehung des ResultSets und die Übergabe an das Tabellenmodell :
Ich hoffe ich bin hier richtig und das ihr mir helfen könnt.
Schonmal Danke
Now
ich bin mir nicht sicher ob es in diesen Bereich des Forums gehört oder doch eher in den der Datenbank.
Ich möchte meiner GUI eine Tabellen hinzufügen.Leider reicht dafür das Standarttablemodel nicht aus da ich auch Checkboxen in einer Spalte haben möchte. Also habe ich mir eine neues Modell erstellt und befülle es direkt mit den Infos aus der Datenbank. Mein Problem ist nun das ich direkt schon beim erstellen der Spaltennamen einen Unknown Source Fehler bekomme als ich versuche vom ResulSet meine Spaltennamen zu lesen.
Das neue Tabellenmodel
Java:
import java.sql.*;
import javax.swing.table.AbstractTableModel;
public class Tabellenmodell extends AbstractTableModel {
String[] spaltennamen = null;
Object [][] tabelleninhalt = null;
Datenbank db = null;
public Tabellenmodell(ResultSet result, Datenbank db)
{
this.db = db;
try{
spaltennamen = new String [result.getMetaData().getColumnCount() + 1];
int i = 1;
while (i <= result.getMetaData().getColumnCount())
{
//Spaltennamen in Array schreiben.
spaltennamen[i - 1] = result.getMetaData().getColumnName(i);
i++;
}
}catch(SQLException e){
System.out.println("Fehler beim Erzeugen der Spaltennamen");
}
try{
tabelleninhalt = new Object[db.getZeilenanzahl()][result.getMetaData().getColumnCount() + 1];
// Tabelleninhalt in Array eintragen
int n = 0;
while(result.next())
{
tabelleninhalt[n][0] = result.getString(1);
tabelleninhalt[n][1] = result.getString(2);
tabelleninhalt[n][2] = new Boolean(false);
n++;
}
}catch(SQLException e){
System.out.println("Fehler beim Erzeugen des Tabelleninhalts");
}
}
public int getColumnCount() {
return spaltennamen.length;
}
public int getRowCount() {
return tabelleninhalt.length;
}
public String getColumnName(int col) {
return spaltennamen[col];
}
public Object getValueAt(int row, int col) {
return tabelleninhalt[row][col];
}
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
}
Der Fehler tritt bein Initialisieren des Arrays Spaltennamen auf. Meine Frage hierzu ist nun ob es überhaupt möglich ist auf diese Weise die Tabelle zu füllen oder ob es einen besseren Weg gibt, den ich nur noch nicht gefunden habe?
der Vollständigkeit halber hier noch die Entstehung des ResultSets und die Übergabe an das Tabellenmodell :
Java:
// Variable für die Rohdaten der Datenbank
ResultSet result = null;
result = db.test();
JTable suchgruende = new JTable(new Tabellenmodell(result, db));
Java:
public ResultSet test()
{
try{
// erstellen einer neuen Abfrage
statement = connection.createStatement();
// ausführen der Abfrage und speichern des Ergebniss
result = statement
.executeQuery("select * from test.tab1");
}catch(SQLException e){
System.out.println("Fehler beim Auslesen der tab1");
}
return(result);
}
Ich hoffe ich bin hier richtig und das ihr mir helfen könnt.
Schonmal Danke
Now
Zuletzt bearbeitet: