ホームページ > Java > &#&チュートリアル > データベースから行を削除した後、JTable が更新されないのはなぜですか?

データベースから行を削除した後、JTable が更新されないのはなぜですか?

Barbara Streisand
リリース: 2024-11-16 11:48:03
オリジナル
676 人が閲覧しました

Why Doesn't My JTable Update After Deleting a Row from the Database?

AbstractTableModel GUI 表示の問題

あなたが直面している問題は、行が削除されたときにテーブル モデルを更新する方法に関連しています。現在、deleteSelectedRow ボタンのアクション リスナーはデータベース内のデータを更新しますが、テーブル モデルの更新をトリガーしません。これが、テーブルに削除された行がまだ表示される理由です。

問題を解決するにはどうすればよいですか?

この問題を解決するには、データが変更されたことをテーブル モデルに明示的に通知する必要があります。これを行うには、データベースから行が削除されるたびに、TableModel インターフェイスの fireTableRowsDeleted() メソッドを呼び出します。これにより、テーブル モデルが内部データ構造を更新し、テーブルを更新するようにトリガーされます。

必要な変更を含む更新バージョンのコードを次に示します。

delete.addActionListener(new ActionListener() {

    @Override
    public void actionPerformed(ActionEvent e) {

        int rowIndex = table.getSelectedRow();

        Object columnIndexValue = table.getModel().getValueAt(rowIndex, 0);

        String columnName = table.getModel().getColumnName(0);

        String query = "delete from world.city" + " where " + columnName + "=" + columnIndexValue;

        try {

            PreparedStatement pre = conn.prepareStatement(query);

            pre.executeUpdate();

            JOptionPane.showMessageDialog(null, "Row Deleted Successfully");
            
            // Notify the table model that the data has changed
            ((TableModel) table.getModel()).fireTableRowsDeleted(rowIndex, rowIndex);

        } catch (Exception e1) {
            JOptionPane.showMessageDialog(null, e1.getMessage());
        }

    }

});
ログイン後にコピー

fireTableRowsDeleted() を呼び出すことにより、 、指定された行を内部データ構造から削除し、それに応じてテーブルを更新するようにテーブル モデルに指示しています。これにより、基礎となるデータベースに加えられた変更が GUI に確実に反映されます。

以上がデータベースから行を削除した後、JTable が更新されないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート