Swing JTable Schlüssel hinzufügen

Status
Nicht offen für weitere Antworten.

multiholle

Aktives Mitglied
Ich möchte Daten aus einem Resultset in einer Tabelle darstellen, dabei werden nicht alle Spalten angezeigt (z. B. ID). Wie kann ich trotzdem die ID zu einem Datensatz "unsichtbar" in einer JTable speichern, um so einen Datensatz eindeutig zu identifizieren?
 
Zuletzt bearbeitet von einem Moderator:

Ebenius

Top Contributor
Die Auswahl der angezeigten Tabellenspalten bestimmt das TableColumnModel (siehe: JTable.getColumnModel()). Du kannst also auch einfach mehr Spalten ins Tabellenmodell machen als von der JTable gezeigt werden.

Ebenius
 

André Uhres

Top Contributor
Ich habe hier einfach mal eines der ResultSetTableModels aus dem Web um zwei Methoden erweitert:
setLeftColumnsHiding(final int leftColumnsHiding) setzt die Anzahl der Spalten fest, die, von links ausgehend, verborgen bleiben sollen
getHidingValueAt(final int row, final int column) ermöglicht den Zugriff auf die verborgenen Werte
Java:
import java.sql.*;
import javax.swing.table.*;

public class ResultSetTableModel extends AbstractTableModel {

    private Connection connection;
    private Statement statement;
    private ResultSet resultSet;
    private ResultSetMetaData metaData;
    private int numberOfRows;
    private boolean connectedToDatabase = false;
    private int leftColumnsHiding = 0;

    public ResultSetTableModel(final String driver, final String url,
            final String query) throws SQLException, ClassNotFoundException {
        Class.forName(driver);
        connection = DriverManager.getConnection(url);
        statement = connection.createStatement(
                ResultSet.TYPE_SCROLL_INSENSITIVE,
                ResultSet.CONCUR_READ_ONLY);
        connectedToDatabase = true;
        setQuery(query);
    }

    @Override
    public Class getColumnClass(final int column) throws IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        try {
            String className = metaData.getColumnClassName(column + 1);
            return Class.forName(className);
        } catch (Exception exception) {
            exception.printStackTrace();
        }
        return Object.class;
    }

    public int getColumnCount() throws IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        try {
            return metaData.getColumnCount() - leftColumnsHiding;
        } // catch SQLExceptions and print error message
        catch (SQLException sqlException) {
            sqlException.printStackTrace();
        }
        return 0;
    }

    @Override
    public String getColumnName(final int column) throws IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        try {
            return metaData.getColumnName(column + 1 + leftColumnsHiding);
        } catch (SQLException sqlException) {
            sqlException.printStackTrace();
        }
        return "";
    }

    public int getRowCount() throws IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        return numberOfRows;
    }

    public Object getValueAt(final int row, final int column)
            throws IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        try {
            resultSet.absolute(row + 1);
            return resultSet.getObject(column + 1 + leftColumnsHiding);
        } catch (SQLException sqlException) {
            sqlException.printStackTrace();
        }
        return "";
    }

    public void setQuery(final String query)
            throws SQLException, IllegalStateException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        resultSet = statement.executeQuery(query);
        metaData = resultSet.getMetaData();
        resultSet.last();                   // move to last row
        numberOfRows = resultSet.getRow();  // get row number
        fireTableStructureChanged();
    }

    public void disconnectFromDatabase() {
        try {
            statement.close();
            connection.close();
        } catch (SQLException sqlException) {
            sqlException.printStackTrace();
        } finally {
            connectedToDatabase = false;
        }
    }

    public void setLeftColumnsHiding(final int leftColumnsHiding) {
        this.leftColumnsHiding = leftColumnsHiding;
    }

    public Object getHidingValueAt(final int row, final int column)
            throws IllegalStateException, IllegalArgumentException {
        if (!connectedToDatabase) {
            throw new IllegalStateException("Not Connected to Database");
        }
        if (column >= leftColumnsHiding) {
            throw new IllegalArgumentException("Wrong column index: " + column +
                    " >= " + leftColumnsHiding);
        }
        try {
            resultSet.absolute(row + 1);
            return resultSet.getObject(column + 1);
        } catch (SQLException sqlException) {
            sqlException.printStackTrace();
        }
        return "";
    }
}
 

Ebenius

Top Contributor
Gerne, leider habe ich mich noch nicht so mit ColumnModels beschäftigt. Wenn's so einfach ist, wie du sagst, dann zeig uns doch bitte mal ein kurzes Beispiel.
Klar. Kein Problem.
Java:
final JTable table = new JTable(4000, 10);

// Let the JTable create the default column model. This would occur later
// (per addNotify), but we want to use the column model before the table
// is displayable
table.createDefaultColumnsFromModel();

// Disable recreating the column model on table structure changed events
// (not necessary for this test, but maybe necessary for other data models)
table.setAutoCreateColumnsFromModel(false);

// Remove the first three columns from the view; show "D"-"J", only
final TableColumnModel colModel = table.getColumnModel();
colModel.removeColumn(colModel.getColumn(0));
colModel.removeColumn(colModel.getColumn(0));
colModel.removeColumn(colModel.getColumn(0));

final JFrame f = new JFrame("Test Frame: A");
f.setContentPane(new JScrollPane(table));
f.pack();
f.setLocationRelativeTo(null);
f.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
f.setVisible(true);
Ebenius
 

André Uhres

Top Contributor
Danke, deine Lösung ist jedenfalls einfacher. Wir könnten es auch so machen:
Java:
SwingUtilities.invokeLater(new Runnable() {
    public void run() {
        colModel = table.getColumnModel();
        colModel.removeColumn(colModel.getColumn(0));
        //...
    }
});
dann brauchen wir kein createDefaultColumnsFromModel() und kein setAutoCreateColumnsFromModel(false) (vorausgesetzt, die GUI wird nach Vorschrift auf dem EDT gestartet).
 

Ebenius

Top Contributor
Ich habe eben nochmal nachgesehen.
[...] Wir könnten es auch so machen: [Java mit invokeLater(...)] Dann brauchen wir kein createDefaultColumnsFromModel() und kein setAutoCreateColumnsFromModel(false) (vorausgesetzt, die GUI wird nach Vorschrift auf dem EDT gestartet).
setAutoCreateColumnsFromModel(false) benötigen wir, wenn das TableModel STRUCTURE_CHANGED-Events verschickt. createDefaultColumnsFromModel() benötigen wir gar nicht. Das wäre nötig, nachdem das TableModel neu gesetzt würde, wenn getAutoCreateColumnsFromModel() false liefern würde. Das invokeLater(...) benötigen wir hier überhaupt nicht. Außer natürlich um die GUI selbst zu initialisieren (was ich mir bei Beispielquelltext spare).

Ebenius
 
G

Gast2

Gast
Ah ok und in die entfernten Column kann man dann so neue Werte hineinschreiben ?
Java:
table.getModel().setValueAt("test", 0, 0);
Ich hab früher einfach immer die Spalten, die nicht sichtbar sein sollten, die column widht auf 0 gesetzt...
 

Ebenius

Top Contributor
Ah ok und in die entfernten Column kann man dann so neue Werte hineinschreiben?
Jupp.

Ich hab früher einfach immer die Spalten, die nicht sichtbar sein sollten, die column widht auf 0 gesetzt...
Das geht halt daneben, wenn man die Columns für den Benutzer resizable halten möchte. Dann müsste man schon minWidth und maxWidth und preferredWidth auf 0 setzen. Aber die Column einfach aus dem ColumnModel zu schmeißen ist schöner. Spart auch der View Aufwand.

Ebenius
 
G

Gast2

Gast
Das geht halt daneben, wenn man die Columns für den Benutzer resizable halten möchte. Dann müsste man schon minWidth und maxWidth und preferredWidth auf 0 setzen. Aber die Column einfach aus dem ColumnModel zu schmeißen ist schöner. Spart auch der View Aufwand.

ja hab natürlich alles auf 0 gehabt... Ja klar ist es schöner aber die Möglichkeit muss man ja erstmal kennen ;)...
Außerdem ist es so viel einfacher ...

Kann man eine Column auch durch ihren Namen entfernen?Also der Text welcher angezeigt wird
 
Zuletzt bearbeitet von einem Moderator:

Ebenius

Top Contributor
jKann man eine Column auch durch ihren Namen entfernen?Also der Text welcher angezeigt wird
Hast Du Dir die API-Doc schonmal angesehen? Da steht eigentlich alles drin. Der Identifier im TableColumnModel ist in den Standardimplementierungen der ColumnName aus dem TableModel. Ergo:
Java:
final JTable table = new JTable(10, 10);
final TableColumnModel columnModel = table.getColumnModel();
final int colAIndex = columnModel.getColumnIndex("A");
final TableColumn colA = columnModel.getColumn(colAIndex);
columnModel.removeColumn(colA);
[size=-2]Code im Browser getippt; Fehler selbständig korrigieren![/size]

Ebenius
 
G

Gast2

Gast
Jupp. Du bist aber flink. Hat nichtmal eine Minute gedauert. :) Ich hätte gern nen Browser, der Code-Verfollständigung in JAVA-BBCode-Tags kann und gleich auch noch testkompiliert. :/

hehe ja des wär nicht schlecht ;)

haha hab mich schon gewundert, weils die Methode nicht gab und dachte ich hab jetzt völlig ein an der Waffel ;)...
ja stimmt so ist die Sache schon viel einfacher...
muss ich mir merken thx.
 

André Uhres

Top Contributor
Das invokeLater(...) benötigen wir hier überhaupt nicht. Außer natürlich um die GUI selbst zu initialisieren (was ich mir bei Beispielquelltext spare).
Ich weiss jetzt nicht mehr, wie ich auf das invokeLater kam. Im einfachsten Fall genügt somit dieser Code:
Java:
colModel = table.getColumnModel();
colModel.removeColumn(colModel.getColumn(0));
//...
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Swing JTable zeichnet kein vertical Grid AWT, Swing, JavaFX & SWT 6
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
K JTable komplett durch andere ersetzen AWT, Swing, JavaFX & SWT 4
S JTable übernimmt Änderungen nicht AWT, Swing, JavaFX & SWT 2
Y JTable AWT, Swing, JavaFX & SWT 6

Ähnliche Java Themen


Oben