So füllen Sie eine JTable aus einem ResultSet auf
Problem:
Sie haben ein Problem Probleme beim Auffüllen einer JTable aus einem ResultSet und dem Empfang einer „IllegalStateException“ Fehler.
Antwort:
Verwendung eines SwingWorker und try-with-resource-Anweisungen:
Um den Code zu vereinfachen und Wenn Sie erweiterte Funktionen nutzen möchten, sollten Sie die Verwendung eines SwingWorker und der try-with-resource-Anweisung in Betracht ziehen. Der SwingWorker ermöglicht die Ausführung von Hintergrundaufgaben, ohne den GUI-Thread zu beeinträchtigen. Die try-with-resources-Anweisung stellt sicher, dass Ressourcen ordnungsgemäß geschlossen werden.
Hier ein Beispiel:
import java.sql.*; import javax.swing.*; import javax.swing.table.*; public class GUI extends JFrame { // ... (remaining GUI code) private void loadData() { LOG.info("START loadData method"); button.setEnabled(false); try (Connection conn = DriverManager.getConnection(url, usr, pwd); Statement stmt = conn.createStatement()) { ResultSet rs = stmt.executeQuery("select * from customer"); ResultSetMetaData metaData = rs.getMetaData(); // Names of columns Vector<String> columnNames = new Vector<>(); int columnCount = metaData.getColumnCount(); for (int i = 1; i <= columnCount; i++) { columnNames.add(metaData.getColumnName(i)); } // Data of the table Vector<Vector<Object>> data = new Vector<>(); while (rs.next()) { Vector<Object> vector = new Vector<>(); for (int i = 1; i <= columnCount; i++) { vector.add(rs.getObject(i)); } data.add(vector); } tableModel.setDataVector(data, columnNames); } catch (Exception e) { LOG.log(Level.SEVERE, "Exception in Load Data", e); } button.setEnabled(true); LOG.info("END loadData method"); } }
Dieser Code verwendet einen SwingWorker, um das Laden der Daten im Hintergrund durchzuführen. Außerdem nutzt es die try-with-resources-Anweisung, um sicherzustellen, dass die Verbindung und die Anweisung ordnungsgemäß geschlossen werden.
Denken Sie daran, url, usr und pwd durch die entsprechenden Werte für Ihre Datenbankverbindung zu ersetzen.
Das obige ist der detaillierte Inhalt vonWie vermeide ich „IllegalStateException' beim Auffüllen einer JTable aus einem ResultSet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!