Hallo zusammen,
ich habe ein kleines JTable problem.
Und zwar:
Ich hab einen JTable (eigene Klasse: QueryTable extends JTable), der zeigt mir Daten von ner Datenbankabfrage an.
Für die Daten habe ich einen Klasse QueryTableModel extends AbstractTableModel.
Die daten werden dort in den Vector <String[]> data gespeichert.
Somit entspricht data.get(zeile)[spalte] der Tabelle.
Nur hab ich in data.get(zeile)[0] ein Spalte, die nicht angezeigt wird im JTABLE, da diese Spalte einen Primary Key beinhaltet, den ich nicht anzeigen will im JTable. Dieser PrimaryKey wird allerdings gebraucht, um später sobald ein Doppelklick auf den JTabel gemacht wird, genau die ausgewählten Daten weiter zu verarbeiten (es geht ein neues Fenster auf wo man diese Daten bearbeiten kann usw.). Bei data.get(zeile)[spalte] startet also spalte bei spalte =1 und nicht bei spalte =0, da spalte =0 der Primary key ist.
Soweit so gut, funktioniert auch alles einwandfrei.
Nun dachte ich mir, ich mach meinen QueryTable (JTable) noch mit setAutoCreateRowSorter(true); schön und schnell sortierbar, was auch klappt!
nun hab ich aber das Problem:
Bevor ich die sortierung hinzu gefügt habe, konnte ich mich verlassen, dass die Selectierte Zeile, die ich mit JTable.getSelectedRow() bekommen habe, genau der Zeile von data.get(zeile)[0] entspricht, um den versteckten Primary Key zu bekommen.
also (PseudoCode):
Nun allerdings, nach dem einfügen von setAutoCreateRowSorter(true), entspricht JTable.getSelectedRow() nicht mehr diesem Index.
Ich dachte, das mein Vector <String[]> data im Model irgendwie sortiert werden würde, dies ist aber nicht der Fall!
Sprich: ich sehe den nach irgend einer Spalte die ich angeklickt habe Sortierten JTable, jedoch haben sich die Daten von meinem Vector<String[]> data nicht mitsortiert, also kann ich auch nicht mehr so über
auf meine daten zugreifen.
MEINE FRAGE:
Irgendwo müssen ja diese sortierten Daten jetzt zwischen gespeichert sein, nur wo? Warscheinlich irgendwo als Object[][] oder?
Wie kann ich am Besten wieder zurückschlussfolgern von den Sortierten Daten zu den ursprünglichen nicht Sortierten daten mit Primary Key, das geht gar nicht oder?
Angenommen ich habe eine kleine Datenbank Tabelle mit id (primary key), vorname, nachname.
mit diese Einträge
id | vorname | nachname
1 | Hans | Mustermann
2 | Julia | Musterfrau
3 | Hans | Mustermann
also würde mein Vector <String[]> data so aussehen:
data.get(0)[0] = 1; data.get(0)[1] = Hans; data.get(0)[2] = Mustermann
data.get(1)[0] = 2; data.get(1)[1] = Julia; data.get(2)[2] = Musterfrau
data.get(2)[0] = 3; data.get(2)[1] = Hans; data.get(1)[2] = Mustermann
Mein Problem ist, das ich wirklich nur anhand der id jeden Eintrag eindeutig identifizieren kann (Primary Key)!
Deshalb speicher ich ja diese Information auch in meinem Vector <String[]> data mit.
Nur angezeigt werden soll diese spalte ID im JTable nicht (das hab ich auch so implementiert und funktioniert).
Nur geht mir warscheinlich jetzt genau diese ID verloren sobald ich im JTable etwas sortiere, da die ursprüngliche Vector <String[]> data aus dem TableModel (QueryTableModel) nicht mit sortiert wird.
Weiß da jemand irgendwie wie ich das machen könnte?
ich habe ein kleines JTable problem.
Und zwar:
Ich hab einen JTable (eigene Klasse: QueryTable extends JTable), der zeigt mir Daten von ner Datenbankabfrage an.
Für die Daten habe ich einen Klasse QueryTableModel extends AbstractTableModel.
Die daten werden dort in den Vector <String[]> data gespeichert.
Somit entspricht data.get(zeile)[spalte] der Tabelle.
Nur hab ich in data.get(zeile)[0] ein Spalte, die nicht angezeigt wird im JTABLE, da diese Spalte einen Primary Key beinhaltet, den ich nicht anzeigen will im JTable. Dieser PrimaryKey wird allerdings gebraucht, um später sobald ein Doppelklick auf den JTabel gemacht wird, genau die ausgewählten Daten weiter zu verarbeiten (es geht ein neues Fenster auf wo man diese Daten bearbeiten kann usw.). Bei data.get(zeile)[spalte] startet also spalte bei spalte =1 und nicht bei spalte =0, da spalte =0 der Primary key ist.
Soweit so gut, funktioniert auch alles einwandfrei.
Nun dachte ich mir, ich mach meinen QueryTable (JTable) noch mit setAutoCreateRowSorter(true); schön und schnell sortierbar, was auch klappt!
nun hab ich aber das Problem:
Bevor ich die sortierung hinzu gefügt habe, konnte ich mich verlassen, dass die Selectierte Zeile, die ich mit JTable.getSelectedRow() bekommen habe, genau der Zeile von data.get(zeile)[0] entspricht, um den versteckten Primary Key zu bekommen.
also (PseudoCode):
Code:
int zeile = JTable.getSelectedRow();
String myPrimaryKey = data.get(zeile)[0];
Nun allerdings, nach dem einfügen von setAutoCreateRowSorter(true), entspricht JTable.getSelectedRow() nicht mehr diesem Index.
Ich dachte, das mein Vector <String[]> data im Model irgendwie sortiert werden würde, dies ist aber nicht der Fall!
Sprich: ich sehe den nach irgend einer Spalte die ich angeklickt habe Sortierten JTable, jedoch haben sich die Daten von meinem Vector<String[]> data nicht mitsortiert, also kann ich auch nicht mehr so über
Code:
int zeile = JTable.getSelectedRow();
String myPrimaryKey = data.get(zeile)[0];
MEINE FRAGE:
Irgendwo müssen ja diese sortierten Daten jetzt zwischen gespeichert sein, nur wo? Warscheinlich irgendwo als Object[][] oder?
Wie kann ich am Besten wieder zurückschlussfolgern von den Sortierten Daten zu den ursprünglichen nicht Sortierten daten mit Primary Key, das geht gar nicht oder?
Angenommen ich habe eine kleine Datenbank Tabelle mit id (primary key), vorname, nachname.
mit diese Einträge
id | vorname | nachname
1 | Hans | Mustermann
2 | Julia | Musterfrau
3 | Hans | Mustermann
also würde mein Vector <String[]> data so aussehen:
data.get(0)[0] = 1; data.get(0)[1] = Hans; data.get(0)[2] = Mustermann
data.get(1)[0] = 2; data.get(1)[1] = Julia; data.get(2)[2] = Musterfrau
data.get(2)[0] = 3; data.get(2)[1] = Hans; data.get(1)[2] = Mustermann
Mein Problem ist, das ich wirklich nur anhand der id jeden Eintrag eindeutig identifizieren kann (Primary Key)!
Deshalb speicher ich ja diese Information auch in meinem Vector <String[]> data mit.
Nur angezeigt werden soll diese spalte ID im JTable nicht (das hab ich auch so implementiert und funktioniert).
Nur geht mir warscheinlich jetzt genau diese ID verloren sobald ich im JTable etwas sortiere, da die ursprüngliche Vector <String[]> data aus dem TableModel (QueryTableModel) nicht mit sortiert wird.
Weiß da jemand irgendwie wie ich das machen könnte?