JTable, AbstractTableModel aus Datenbank initialisieren

Nowster

Mitglied
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
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:

java253

Mitglied
Ich verstehe noch nicht, was dein TableModel können soll, was DefaultTableModel nicht kann.
Booleans werden standardmäßig als Checkbox dargestellt:

Java:
JTable table = new JTable() {
     @Override
     public Class getColumnClass(int column) {
          if(column == 0) return Boolean.class; //Angenommen, Spalte 0 ist die CheckBox-Spalte
          else return Object.class;
     }
};
table.setModel(new DefaultTableModel(3,4));
table.setValueAt(true, 1, 0);
 

Nowster

Mitglied
Ich habe diesen Artikel über Table gelesen :
klick mich

Dort steht das man um checkboxen darstellen zu können sich ein eigenes Tablemodel erstellen müsse.

im Prinzip möchte ich nur eine Tabelle die eine integer eine String und eine Checkbox Spalte besitzt.
 
Zuletzt bearbeitet:

Nowster

Mitglied
ok sah am Anfang gut aus aber irgendwie bin ich noch nicht so richtig durchgestiegen mein Code sieht jetzt so aus:
Java:
ResultSet result = null;
				//liefert ein Resultset über den Inhalt der Tabelle aus der DB
				result = db.getSuchgruende();
				JTable table = new JTable(); {
     							public Class getColumnClass(int column) {
          							if(column == 2) return Boolean.class; 
          							else return Object.class;
     								}
								}; 
								
								
								try{
								int spaltenzahl = result.getMetaData().getColumnCount();
								table.setModel(new DefaultTableModel(db.getZeilenanzahl(),spaltenzahl));
								int i = 0;
								
								while(result.next())
								{
									table.setValueAt(result.getString(1), 1, i);
									table.setValueAt(result.getString(2), 2, i);
									table.setValueAt(new Boolean(false), 3, i);
									i++;
								}
								}catch(SQLException e) {
									
									System.out.println("Tabelle konnte nicht erstellt werden");
									
								}

Was ich eigentlich bauen wollte war eine Tabelle in der 1. und 2. Spalte Strings aus der DB und in der 3. eine Checkbox. Ausserdem sollten , wenn ich die Tabelle habe, auch noch die Spaltennahmen aus dem gleichen ResulSet wie die anderen Daten gelesen werden. nur bekomme ich im Moment eine Tabelle ohne Spaltenüberschrift mit 5 Zeilen und 2 spalten die leer sind auch wenn ich die Zeilen und Spalten Zahlen per Hand eintrage.

diese Tabelle hält mich nun schon 7 Stunden auf :(.

MfG
Now
 

java253

Mitglied
Java:
table.setModel(new DefaultTableModel(db.getZeilenanzahl(), spaltenzahl + 1));
Java:
model.setColumnIdentifiers(new String["Spalte 1", "Spalte 2", "Spalte 3"]);
 

Nowster

Mitglied
sooo weiter 8 stunden sind ins land gegangen und immerhin habe ich jetzt eine Tabelle die mit den richtigen Daten gefüllt ist :D. aber nun fehlen noch die Spalten Überschriften.

Leider konnte ich mit den Codefragmenten von Java 253 nicht viel anfangen.

so sieht der Code zu meiner Tabelle jetzt aus:
Java:
 String daten[][];
				//holen der Daten in Form eines 2 dimensionalen Arrays
				daten = db.getSuchgruende();
				JTable table = new JTable(){
			     public Class getColumnClass(int column) {
			          if(column == 2) return Boolean.class; 
			          else return Object.class;
			     }
			};
			        // holen Zeilen und Spaltenzahlen aus Klasse db
				int zeilenzahl = db.getZeilenanzahl("test");
				int spaltenzahl = db.getSpaltenanzahl("test");

                                //Neues Tabellenmodell der Tabelle hinzufügen
				table.setModel(new DefaultTableModel(zeilenzahl,spaltenzahl + 1));
				int i = 0;
				while(zeilenzahl > i)
				{
					table.setValueAt(daten[i][0], i, 0);
					table.setValueAt(daten[i][1], i, 1);
					table.setValueAt(new Boolean(false), i, 2);
					i++;
				}
				
				
				
				//Schriftart und Größe setzen
				table.setFont(new Font("Times New Roman", Font.BOLD, 16));
				
				//Text des in spalte 2 hat 30 Stellen.
				TableColumn column = null;
				column = table.getColumnModel().getColumn(1);
				column.setPreferredWidth(250);
				
				final JScrollPane sp1 = new JScrollPane();
		        sp1.setPreferredSize(new Dimension(600, 200));
		        sp1.setViewportView(table);

vll könnt ihr mir ja nochmal helfen :).

komme mir langsam wirklich doof vor so oft wegen der blöden GUI fragen zu müssen.
 

Nowster

Mitglied
ok vergesst es habs gelöst :D

Java:
//Setzen der TabellenÜberschriften
				TableColumn column = null;
				column = table.getColumnModel().getColumn(0);
				column.setHeaderValue(daten[0][0]);
				column = table.getColumnModel().getColumn(1);
				//Text des Suchgrunds hat 30 Stellen.
				column.setPreferredWidth(250);
				column.setHeaderValue(daten[0][1]);
				column = table.getColumnModel().getColumn(2);
				column.setHeaderValue("Löschen");

trotzdem Danke an alle die das gelesen haben :D
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Swing Print JTable mit AbstractTableModel AWT, Swing, JavaFX & SWT 1
I JTable,AbstractTableModel Problem AWT, Swing, JavaFX & SWT 3
I JTable und AbstractTableModel AWT, Swing, JavaFX & SWT 10
H JTable - DefaultTableModel vs AbstractTableModel AWT, Swing, JavaFX & SWT 5
K Swing jTable und AbstractTableModel AWT, Swing, JavaFX & SWT 6
Ollek Swing JTable - Zeile löschen mit AbstractTableModel AWT, Swing, JavaFX & SWT 20
K JTable & AbstractTableModel AWT, Swing, JavaFX & SWT 9
G JTable (AbstractTableModel) wird nicht aktualisiert AWT, Swing, JavaFX & SWT 2
D JTable, DefaultTableCellRenderer & AbstractTableModel AWT, Swing, JavaFX & SWT 11
N JTable repaint mit AbstractTableModel AWT, Swing, JavaFX & SWT 2
J Drag und drop aus einer JTable - bitte um Unterstützung AWT, Swing, JavaFX & SWT 2
S HPRO und UPRO gemeinsame JTABLE gemeinsamer RENDERER ? AWT, Swing, JavaFX & SWT 1
F Swing JTable - MultiHeader inkl. Eingabemöglichkeit AWT, Swing, JavaFX & SWT 1
S JTable - Feldinhalte anzeigen AWT, Swing, JavaFX & SWT 15
D Swing JTable Spaltenbreite AWT, Swing, JavaFX & SWT 1
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
G jTable - getSelectedRow() AWT, Swing, JavaFX & SWT 3
I JTable mit einem Button zu einer Detail Seite springen AWT, Swing, JavaFX & SWT 4
P JTable Listener für die Änderung einzelner Zellen oder Rows AWT, Swing, JavaFX & SWT 2
D Tastaturabfragen CTRL+t, CTRL+E bei eine JTable, bestehend aus JTextAteas AWT, Swing, JavaFX & SWT 4
P Checkboxes in JTable nicht editable AWT, Swing, JavaFX & SWT 9
F Best-Practise: JTable Text in Zelle zu groß AWT, Swing, JavaFX & SWT 2
izoards JTable in CSV File schreiben... AWT, Swing, JavaFX & SWT 23
Kohl Jedes Objekt einer JTable um ein Zeichen verkürzen AWT, Swing, JavaFX & SWT 7
I JTable, DefaultTableModel, zwei Zahlen multiplizieren. AWT, Swing, JavaFX & SWT 26
M JTABLE / wie oft wurde gewürfelt. AWT, Swing, JavaFX & SWT 1
F JTable vergrößern AWT, Swing, JavaFX & SWT 2
H JTable: Diverse NullPointer-Exceptions zur Laufzeit AWT, Swing, JavaFX & SWT 3
J Swing Werte des JTable werden nicht angezeigt AWT, Swing, JavaFX & SWT 9
T Swing JTable cellRenderer mit jpg Hintergrundfarbe lässt sich nicht ändern. AWT, Swing, JavaFX & SWT 1
HoT Einzelne Zelle in JTable Rahmen unten setzen AWT, Swing, JavaFX & SWT 24
B JTable Zellen zusammenfügen AWT, Swing, JavaFX & SWT 3
M Swing Cell Renderer für Zeilenumbruch in JTable AWT, Swing, JavaFX & SWT 0
H JTable im JSplitPane darstellen AWT, Swing, JavaFX & SWT 2
MadMax2506 Swing JTable lädt sehr lange AWT, Swing, JavaFX & SWT 1
D Zeilenumbruch in einer JTable AWT, Swing, JavaFX & SWT 9
R Swing JTable und Spaltenausrichtung AWT, Swing, JavaFX & SWT 8
G JTable füllen AWT, Swing, JavaFX & SWT 1
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
W Swing JTable Zeilenumbruch innerhalb einer Zelle AWT, Swing, JavaFX & SWT 3
J Datensatz in jTable ausgeben AWT, Swing, JavaFX & SWT 3
M Swing Automatischer Editorstart in JTable-Zelle AWT, Swing, JavaFX & SWT 5
ralfb1105 Swing JTable aktualisieren AWT, Swing, JavaFX & SWT 5
adiko01 JTable: Nur markierte Zeilen aus der Tabelle in CSV exportiern AWT, Swing, JavaFX & SWT 9
M JTable.setDefaultRenderer(...) greift nicht AWT, Swing, JavaFX & SWT 0
J JTable: Eingabe in Tabellenzelle korrigieren AWT, Swing, JavaFX & SWT 4
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
D JTable nach INSERT aktualisieren /refreshen AWT, Swing, JavaFX & SWT 1
D MySQL Daten in JTable anzeigen AWT, Swing, JavaFX & SWT 2
H Swing Jtable extra spalte AWT, Swing, JavaFX & SWT 6
S Swing Rechteck über JTable zeichnen (per MouseListener) AWT, Swing, JavaFX & SWT 1
S Swing Mal wieder JTable Ansicht aktualisieren AWT, Swing, JavaFX & SWT 10
A JTable mit Daten füllen AWT, Swing, JavaFX & SWT 1
VfL_Freak Swing Einzelne Zeile in jTable selektieren klappt nicht AWT, Swing, JavaFX & SWT 7
N AWT jTable CellRenderer AWT, Swing, JavaFX & SWT 6
T Swing JTable valueChanged datensatz löschen AWT, Swing, JavaFX & SWT 1
0 Swing JTable aus anderer Klasse updaten AWT, Swing, JavaFX & SWT 5
S Jtable defaultRenderer wohin damit ? AWT, Swing, JavaFX & SWT 23
T Swing JTable / FocusListener AWT, Swing, JavaFX & SWT 0
it_is_all Warum wird die JTable im JDialog nicht angezeigt? AWT, Swing, JavaFX & SWT 1
L Swing JTable im Panel darstellen AWT, Swing, JavaFX & SWT 8
T Swing Double Click bei Buttons in JTable AWT, Swing, JavaFX & SWT 9
J addRow bei JTable AWT, Swing, JavaFX & SWT 6
M Jtable gibt -1 wert bei selectedRow und Column AWT, Swing, JavaFX & SWT 3
Meeresgott Swing JTable AWT, Swing, JavaFX & SWT 4
J JTable Selection Listener funktioniert nicht AWT, Swing, JavaFX & SWT 4
C Swing Daten in JTable wiedergeben per TableModel und MVC Pattern AWT, Swing, JavaFX & SWT 16
Z Swing Drag&Drop zwischen JTable und JTree AWT, Swing, JavaFX & SWT 4
Thallius JTable dynamisch Spaltenanzahl verändern AWT, Swing, JavaFX & SWT 2
Thallius JTable dynamisch laden? AWT, Swing, JavaFX & SWT 2
B Swing JTable sortieren AWT, Swing, JavaFX & SWT 2
T Swing JTable auslesen und befüllen AWT, Swing, JavaFX & SWT 8
B JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 1
J JTable und Suchlogik AWT, Swing, JavaFX & SWT 4
Viktim Swing JTable mit Tab verlassen AWT, Swing, JavaFX & SWT 1
F Swing Spaltenbreite einer Column eines JTable auslesen AWT, Swing, JavaFX & SWT 5
Viktim Swing JTable Mit Tab druch Zeilen Wechseln AWT, Swing, JavaFX & SWT 5
Thallius Warum refrehsed mein JTable nicht? AWT, Swing, JavaFX & SWT 5
Ghostman1711 Hinzufügen ausgewählter Dateinen des Filechoosers zu einem JTable AWT, Swing, JavaFX & SWT 9
S Swing JTable - Einzelne Rows einfärben AWT, Swing, JavaFX & SWT 11
M Wert einer Zelle aus JTable ziehen AWT, Swing, JavaFX & SWT 4
K JTable getValueAt() klappt nicht immer AWT, Swing, JavaFX & SWT 1
K JTable in extra Klasse, Zugriff in einer anderen klasse nicht möglich AWT, Swing, JavaFX & SWT 26
B Swing Tabelle(JTable) filtern swing GUI AWT, Swing, JavaFX & SWT 3
P JTable - bei Eingabe Selektion AWT, Swing, JavaFX & SWT 0
P Fokus auf Zelle in JTable AWT, Swing, JavaFX & SWT 1
S Swing Deselektion in JTable verhindern AWT, Swing, JavaFX & SWT 0
D Problem mit JTable AWT, Swing, JavaFX & SWT 1
Ananaskirsche Swing jTable Reihen zuviel eingefügt AWT, Swing, JavaFX & SWT 12
P im JTable die Schriftfarbe ändern AWT, Swing, JavaFX & SWT 19
T Swing JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 4
S Dreiecke in bestimmte Zellen einer JTable AWT, Swing, JavaFX & SWT 9
LexeB4F Zelle in JTable gezielt einfärben AWT, Swing, JavaFX & SWT 4
LexeB4F JTable mehrere Zelle selektieren und inhalte Löschen.. Ideen gesucht AWT, Swing, JavaFX & SWT 1
D Swing JTable Renderer Grafikfehler AWT, Swing, JavaFX & SWT 0
K Swing JTable mit ImageIcon und Text in einer Zelle AWT, Swing, JavaFX & SWT 1
M Swing JTable GroupableHeader Background Color AWT, Swing, JavaFX & SWT 4
K Swing JTable updaten AWT, Swing, JavaFX & SWT 9
thet1983 Swing MySQL >> JTable AWT, Swing, JavaFX & SWT 5
J JTable bounds ändern durch resizing des Fensters AWT, Swing, JavaFX & SWT 9

Ähnliche Java Themen

Neue Themen


Oben