Как обновить JTable в графическом интерфейсе из базы данных?

Здесь я подключаю свою базу данных:

package org.connect;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

public class dbconnect {

    public static Connection getConnectionvalue() {
        Statement stmt = null;
        Connection con = null;
        try {
            Class.forName("oracle.jdbc.OracleDriver");
            String url = "jdbc:oracle:thin:@localhost:1521:xe";
            con = DriverManager.getConnection(url, "system", "kingdom");
            con.setAutoCommit(true);
        } catch (Exception e) {
            System.out.println("Connection Error" + e);
        }
        return con;
    }

    public static Statement
    getStatementvalue() {
        Statement stmt = null;
        Connection con = null;
        try {
            Class.forName("oracle.jdbc.OracleDriver");
            String url = "jdbc:oracle:thin:@localhost:1521:xe";
            con = DriverManager.getConnection(url, "system", "kingdom");
            con.setAutoCommit(true);
            stmt = con.createStatement();
        } catch (Exception e) {
            System.out.println("Connection Error" + e);
        }
        return stmt;
    }
}

Здесь я создал фрейм и получил значения таблицы базы данных. А потом я передал набор результатов табличных значений в Deptmodeltable

package org.frames.src;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.event.ActionEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.sql.RowSetEvent;
import javax.sql.RowSetListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;

import org.connect.dbconnect;
import org.reports.master.TESTJASPER;
import org.table.model.DeptTableModel;

import java.awt.event.ActionListener;
import java.io.IOException;

public class DeptFrame extends JFrame implements RowSetListener, ActionListener {

    Statement stmt = dbconnect.getStatementvalue();
    Connection con = dbconnect.getConnectionvalue();
    public static JTable table; // The table for displaying data
    public static JScrollPane scrollPane;
    public static JPanel mainpanel, panel, panel1;
    public static JButton button;
    DeptTableModel depttm;

    public DeptFrame() throws SQLException {
        super("The Masters: Department");
        addWindowListener(new WindowAdapter() {
            public void windowClosing(WindowEvent e) {
                try {
                    con.close();
                } catch (SQLException sqle) {
                    System.out.println("windowClosing" + sqle);
                }
                System.exit(0);
            }
        }
        );

        ResultSet rstable = getContentsOfTable();
        depttm = new DeptTableModel(rstable);

        table = new JTable(); // Displays the table
        table.setModel(depttm);
        table.setForeground(Color.gray);
        table.setBackground(Color.ORANGE);
        table.setRowSelectionAllowed(true);
        table.setColumnSelectionAllowed(false);
        table.setSize(300, 300);
        scrollPane = new JScrollPane(table);

        button = new JButton("ViewReport");

        button.addActionListener(this);
        mainpanel = new JPanel();

        panel1 = new JPanel();

        panel1.add(button);
        mainpanel.setLayout(new BorderLayout());
        mainpanel.add(scrollPane);
        mainpanel.add("South", panel1);
    }

    /**
     * @param args * @throws SQLException
     */
    public static void main(String[] args)
            throws SQLException {
        DeptFrame df = new DeptFrame();
        df.add(mainpanel);
        df.setSize(700, 700);
        df.getContentPane().add(mainpanel);
        df.setVisible(true);
    }

    public ResultSet getContentsOfTable() throws SQLException {
        ResultSet rs = null;
        try {
            rs = stmt.executeQuery("select * from M_department");
        } catch (SQLException e) {
            System.out.println("Query" + e);
        }
        return rs;
    }

    @Override
    public void cursorMoved(RowSetEvent arg0) {
    }

    @Override
    public void rowChanged(RowSetEvent arg0) {
    }

    @Override
    public void rowSetChanged(RowSetEvent event) {
    }

    @Override
    public void actionPerformed(ActionEvent e) {         // TODO Auto-generated method stub         String action =
        e.getActionCommand();
        if (action.equals("ViewReport")) {
            String[] args = null;
            TESTJASPER.main(args);
            try {
                TESTJASPER.openPdf();
            } catch (IOException e1) {             // TODO
                Auto - generated catch block e1.printStackTrace();
            } catch
                    (InterruptedException e1) {             // TODO Auto-generated catch block
                e1.printStackTrace();
            }
        }
    }
}

Здесь я реализую слушатель модели таблицы и устанавливая значения JTable

package org.table.model;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;

import javax.sql.RowSet;
import javax.sql.RowSetListener;
import javax.sql.rowset.CachedRowSet;
import javax.swing.JTable;
import javax.swing.event.TableModelListener;
import javax.swing.table.TableModel;

import oracle.jdbc.rowset.OracleCachedRowSet;
import org.connect.dbconnect;
import org.frames.src.DeptFrame;

public class DeptTableModel implements TableModel {
    Statement stmt = dbconnect.getStatementvalue();
    Connection con = dbconnect.getConnectionvalue();
    static ResultSet rsdept;
    ResultSetMetaData metadata; // Additional information about the results
    int numcols, numrows;
    public OracleCachedRowSet ocrs;

    public ResultSet getDeptRowSet() {
        return rsdept;
    }

    public DeptTableModel(ResultSet rsarg) throws SQLException {
        this.rsdept = rsarg;
        this.metadata = this.rsdept.getMetaData();
        this.numcols = metadata.getColumnCount();
        ocrs = new OracleCachedRowSet();
        ocrs.populate(this.rsdept);
        ocrs.beforeFirst();
        this.numrows = 0;
        while (ocrs.next()) {
            this.numrows++;
        }
        ocrs.beforeFirst();
        //System.out.println(numrows);      //System.out.println(numcols);  }

    public void close() {
        try {
            rsdept.getStatement().close();
        } catch (SQLException e) {
            System.out.print(e);
        }
    }

    /**
     * Automatically close when we're garbage collected
     */
    protected void finalize() {
        close();
    }

    @Override
    public void addTableModelListener(TableModelListener arg0) {         // TODO Auto - generated method stub
    }

    @Override
    public Class
    getColumnClass(int column) {
        return String.class;
    }

    @Override
    public int getColumnCount() {
        return numcols;
    }

    @Override
    public String
    getColumnName(int column) {
        try {
            return this.metadata.getColumnLabel(column + 1);
        } catch (SQLException e) {
            return e.toString();
        }
    }

    @Override
    public int getRowCount() {
        return numrows;
    }

    @Override
    public Object getValueAt(int rowIndex, int columnIndex) {
        try {
            ocrs.absolute(rowIndex + 1);
            Object o = ocrs.getObject(columnIndex + 1);
            if (o == null)
                return null;
            else
                return o.toString();
        } catch (SQLException e) {
            System.out.print(e);
            return e.toString();
        }
    }

    @Override
    public boolean isCellEditable(int rowIndex, int columnIndex) {
        if (columnIndex != 0) {
            return true;
        } else {
            return false;
        }
    }

    @Override
    public void
    removeTableModelListener(TableModelListener arg0) {         // TODO Auto - generated method stub
    }

    @Override
    public void setValueAt(Object value, int row, int column) {
        System.out.println("Calling setValueAt row " + row + ", column " + column + " value is" + value.toString());

        System.out.println(getColumnName(column));
        System.out.println(getValueAt(row, 0));
        String updateq = "update M_department set " + getColumnName(column) + "='" + value.toString()
                + "' where code = '" + getValueAt(row, 0) + "' ";
        System.out.println(updateq);
        try {
            stmt.executeUpdate(updateq);
            DeptFrame x = new DeptFrame();
            new DeptTableModel(x.getContentsOfTable());
        } catch (SQLException e) {             // TODO Auto-generated catch block
            e.printStackTrace();
            System.out.println("Error" + e);
        }
    }
}

Все работает нормально, но мой jtable не обновляется после обновления строки

1 ответ

У вас есть в нижней части дна

  stmt.executeUpdate(updateq);  
  DeptFrame x=new DeptFrame();   
  new DeptTableModel(x.getContentsOfTable());  

1) я вижу stmt.executeUpdate звоните, но я не вижу commit звонки. у вас включен автокоммит? я думал, что у oracle это было отключено по умолчанию, поэтому происходит выполнение, но тогда новая модель frame+ имеет старый контент, потому что новый контент никогда не фиксируется?

2) почему вы создаете * еще один DeptTableModel без ссылок там? это выглядит как DeptFrame уже создает один внутри, так для чего этот второй?

Другие вопросы по тегам