JTable Datensätze bleiben immer gleich

c-i-k-o

Mitglied
Hallo Zusammen,

ich bin gerade dabei eine Tabelle mit JTable zu basteln.
Leider habe ich das Problem, dass in jeder Zeile die gleichen Datensätze angezeigt werden.

wie z.b.

ID Name Vorname
1 Muster Max
1 Muster Max
1 Muster Max
1 Muster Max
... usw.

Dazu kommt auch eine Fehlermeldung:
java.lang.ArrayIndexOutOfBoundsException: 27 >= 27Fehler
(27 ist die Anzahl der Datensätze in der DB).

ich stell den Quellcode einfach mal ein vielleicht habt ihr eine Idee.

Java:
import java.util.* ;
import javax.swing.*;
import java.awt.*;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.swing.table.DefaultTableModel;
class Personal 
{

    public static void main ( String[] args)
    {
        SqlKlasse sql = new SqlKlasse();
        JFrame f = new JFrame();
        f.setVisible(true);
        f.setBounds(200,200,700,500);

        Vector <String> haeder = new Vector <String>();
        Vector<Vector<String>> rows = new Vector<Vector<String>>();
        Vector <String> column = new Vector <String>();
        haeder.addElement("ID");
        haeder.add("Name");
        haeder.add("Vorname");
        JTable tbl = new JTable(rows, haeder);
        JScrollPane sp = new JScrollPane(tbl);
        f.add(sp);

        try 
        {
            sql.openConnection();
            Statement statement = sql.connection.createStatement();
            ResultSet rs = statement.executeQuery ("select * from ma");

            for (int i = 0 ; i <rows.capacity();i++)
            {
                while (rs.next())
                {
                    column.addElement(rs.getString(1));
                    column.addElement(rs.getString(2));
                    column.addElement(rs.getString(3));
                    rows.add(column);  
                }

                rows.elementAt(i);
            }
            DefaultTableModel model = (DefaultTableModel)tbl.getModel();
            model.addRow(rows);
            sql.connection.close();
        }catch(Exception e)
        {
            System.out.println("Fehler+e");
        }

    }

}

irgendwie komme ich nicht mehr weiter.
Freue mich auf jede Hilfe

Gruß
c-i-k-o
 

VfL_Freak

Top Contributor
Moin,

in welcher Zeile tritt die Exception denn auf ???:L

BTW: wozu ist denn das einsame "rows.elementAt(i)" nach der while-Scheife gut ???:L

Gruß
Klaus
 

Michael...

Top Contributor
Das liegt daran, dass Du den Vector "column" (der entgegen seinem Namen wohl die Zeileninhalte speichern soll) immer wieder verwendest.
Du musst für jede Zeile auch einen neuen Vector verwenden, sonst steht in Deiner Tabelle immer die zuletzt eingelesene Zeile.
 

c-i-k-o

Mitglied
Vielen Dank für die super schnellen Antworten...


Das liegt daran, dass Du den Vector "column" (der entgegen seinem Namen wohl die Zeileninhalte speichern soll) immer wieder verwendest.
Du musst für jede Zeile auch einen neuen Vector verwenden, sonst steht in Deiner Tabelle immer die zuletzt eingelesene Zeile.

Kannst du mir das vielleicht einwenig erklären. ich verstehe nicht so ganz wie ich das umsetzen soll..
Das was ich mir jetzt darunter vorstelle ist:

Java:
while (rs.next())
                {
                    column.addElement(rs.getString(1));
                    column.addElement(rs.getString(2));
                    column.addElement(rs.getString(3));
                    rows.add(column);  
                }

while (rs.next())
                {
                    column2.addElement(rs.getString(1));
                    column2.addElement(rs.getString(2));
                    column2.addElement(rs.getString(3));
                    rows.add(column2);  
                }
column3....column4....

das wird wohl kaum richtig sein...

Würde mich freuen, wenn du mir das bisschen erklären könntest.(Ich bin nämlich noch sehr sehr neu in der Java-Welt :oops:)
 

c-i-k-o

Mitglied
Moin,

in welcher Zeile tritt die Exception denn auf ???:L

Also die Exception steht in der 48.-51. Zeile.

BTW: wozu ist denn das einsame "rows.elementAt(i)" nach der while-Scheife gut ???:L

Gruß
Klaus

Vor der While-Schleife habe ich eine For-Schleife eingebaut, weil sonst immer nur eine Zeile ausgegeben wird... Es sollen aber alle Datensätze aus der DB ausgegeben werden, und das klappt nicht ???:L

und da habe ich mir gedacht, dass ich die Schleife bis zur Kapazitätsgrenze (i <rows.capacity()) hochzählen lasse und dann jeweils die Zeilen per row.elementAt(i) ausgeben lasse... denn mit rs.next() wird nur ein Datensatz ausgegeben.
 
Zuletzt bearbeitet:

Michael...

Top Contributor
Die Schleife über den Vector rows ist nicht nur nutzlos sondern falsch.

Es reicht vollkommen per while über den ResultSet zu iterieren. Hier muss aber für jede neue Zeile auch ein neuer Vector angelegt
Code:
new Vector <String>()
und mit den Daten des ResultSets befüllt werden
 

c-i-k-o

Mitglied
ok jetzt habe ich es auch verstanden. Der Vector muss in bei jedem Durchlauf der while Schleife neu angelegt werden. Logisch (auch wenns etwas spät ist habe ich es bemerkt :))

aber jetzt das Problem.. wenn ich die for-Schleife weglasse, dann werden nur 5 Zeilen ausgegeben :( (ist mit sicherheit wieder was simpeles wovon ich keinen Plan habe :oops:)
 
S

SlaterB

Gast
ist
> model.addRow(rows);
noch aktiv? damit wird alles als nur eine Row hinzugefügt

setDataVector() ist für mehrere Rows gedacht, oder in der Schleife gleich mehrfach addRow()

bezieht sich
> werden nur 5 Zeilen ausgegeben
generell nur auf die GUI?
schlechtes Vorgehen, immer erst mit System.out.println() anfangen, logge in der Schleife, wie oft wird diese durchlaufen?
mit konkret welchen Einträgen, falls es wirklich nur 5 sind, welche 5, von wievielen und welche in der DB?
 
S

SlaterB

Gast
und ich verstehe nicht, was du nicht verstehst,
du kannst es dabei belassen oder erklären was du nicht verstehst

angefangen mit
Java:
ist
> model.addRow(rows);
noch aktiv? damit wird alles als nur eine Row hinzugefügt
ich werde es nicht neuformulieren,
ist der Sinn dieser Aussage unklar, auch nicht durch Fragen/ Vermutungen/ Tests/ Nachschlagen der Methodenbeschreibung
in irgendeiner Form näher zu ermitteln?
 

Flown

Administrator
Mitarbeiter
Du siehst nur 5, doch es sind 27?

- Zähl in der schleife mit wieviele Datensätze es sind
- Wenn mehere drinnen sind, dann versuch es doch mit: setAutoscrolls(true) bei der table
 

c-i-k-o

Mitglied
Danke an Alle...
ich habe wie SlaterB es empfohlen hat, model.addRow(rows); einfach weggelassen... jetzt klappt es...



Vielen Dank nochmal an Alle!
 
S

SlaterB

Gast
das war zwar nicht genau mein Tipp, aber jetzt sehe ich, dass das durchaus besser dadurch wird,

setVisible(true) sollte übigens ganz am Ende,
sonst können spätere Änderungen immer aufwendig werden,
ohne einen Aufruf am Model würde das auf Änderungen gar nicht reagieren, fireTableDataChanged() usw. empfehlenswert,

aber wenn alles in der Initialisierung stattfindet, welche durch setVisible(true) abgeschlossen wird, dann akzeptabel
 

c-i-k-o

Mitglied
Danke für den Tipp, werde ich auf jeden ändern.

Ich kenn mich leider noch nicht so gut aus in der Java-Welt, bin noch in der Lernphase.... Aber das mit fireTableDataChanged() u.ä. werde ich mir alles genauer anschauen ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Swing Datensätze aus DB in jTable einfügen AWT, Swing, JavaFX & SWT 2
E Datensätze in JTable anzeigen AWT, Swing, JavaFX & SWT 5
B Datensätze einer Datenbank in JTable ausgeben AWT, Swing, JavaFX & SWT 14
R JTable: Maus-Click ohne Datensätze AWT, Swing, JavaFX & SWT 9
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
N Swing Print JTable mit AbstractTableModel 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
F JTable Zellen-Hintergrund ändern AWT, Swing, JavaFX & SWT 7
O JTable linksbündig drucken (nicht der Zelleninhalt) AWT, Swing, JavaFX & SWT 2
Crazynet xls Datei in JTable AWT, Swing, JavaFX & SWT 3
O JTable ohne Rahmen printen AWT, Swing, JavaFX & SWT 3
L Swing JTable refresht die Column Namen nicht AWT, Swing, JavaFX & SWT 0

Ähnliche Java Themen

Neue Themen


Oben