Heim > Java > javaLernprogramm > Wie vermeide ich „IllegalStateException' beim Auffüllen einer JTable aus einem ResultSet?

Wie vermeide ich „IllegalStateException' beim Auffüllen einer JTable aus einem ResultSet?

Linda Hamilton
Freigeben: 2024-12-21 09:46:10
Original
455 Leute haben es durchsucht

How to Avoid

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");
    }

}
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage