刷新 JFrame 内容 DefaultTableModel

Refresh JFrame contents DefaultTableModel

我正在尝试弄清楚如何使用另一个站点的示例在模型发生更改后进行 table window 更新。一切正常,但我不知道如何在 table 模型更改后刷新 window。

编辑:我使用了 Bell 的建议并重新安排了一些东西,以便构造函数调用我的 getmodel3 方法来填充 table。我以为我可以使用 setmodel 方法来更改模型并更新 table 但它没有像我想的那样工作。这是我认为会发生但没有发生的事情:

  1. main 方法使用从 getmodel3 方法传递的模型创建 table 的新实例。
  2. 构建 table 后,我调用 setmodel 方法使用从 getmodel4 返回的模型将不同的数据加载到新模型中。
  3. 步骤 1 中的实例使用新模型数据更新,新数据显示在 table。

实际发生的是,创建了一个新实例并使用从 getmodel3 返回的模型,然后 setmodel 方法运行并从不同的数据集更新模型变量,但是table 未显示更改。

    public class myTable extends JFrame
    {

    public volatile DefaultTableModel model = (DefaultTableModel) myTable.getmodel3();

    public void setmodel(DefaultTableModel newModel) 
    {
        this.model = newModel;
    }

    public myTable()
    {
        JTable table = new JTable( model );
        JScrollPane scrollPane = new JScrollPane( table );
        getContentPane().add( scrollPane );
        JPanel buttonPanel = new JPanel();
        getContentPane().add( buttonPanel, BorderLayout.SOUTH );
    }

    public static void main(String[] args)
    {
        myTable frame = new myTable();
        frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
        frame.pack();
        frame.setVisible(true);
        frame.setmodel(getmodel4());
    }   

这里是 getmodel3,它与 getmodel4 相同,只是它们针对不同的数据指向不同的数据库文件。

    public static DefaultTableModel getmodel3(){
    Vector<Object> columnNames = new Vector<Object>();
    Vector<Object> data = new Vector<Object>();

    try
    {
        //  Connect to an Access Database

        String url = "jdbc:sqlite:c:\sqlite3\test.db";
        Connection conn = DriverManager.getConnection(url);

        //  Read data from a table

        String sql = "Select * from Tasks";
        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery( sql );
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();

        //  Get column names

        for (int i = 1; i <= columns; i++)
        {
            columnNames.addElement( md.getColumnName(i) );
        }

        //  Get row data

        while (rs.next())
        {
            Vector<Object> row = new Vector<Object>(columns);

            for (int i = 1; i <= columns; i++)
            {
                row.addElement( rs.getObject(i) );
            }

            data.addElement( row );
        }

        rs.close();
        stmt.close();
        conn.close();
    }
    catch(Exception e)
    {
        System.out.println( e );
    }

    //  Create table with database data

    DefaultTableModel model = new DefaultTableModel(data, columnNames)
    {
        @Override
        public Class getColumnClass(int column)
        {
            for (int row = 0; row < getRowCount(); row++)
            {
                Object o = getValueAt(row, column);

                if (o != null)
                {
                    return o.getClass();
                }
            }

            return Object.class;
        }
    };
System.out.println("got model");

return model;

}

您可以通过 table.getModel() 使用现有模型并使用 table.setModel(yourModel)

设置 new/existing 模型
DefaultTableModel model = (DefaultTableModel) table.getModel();
// do modification here
table.setModel(model);

嗯,在你的帮助下我终于弄明白了。 setModel 没有工作,因为 1,它无法从我尝试使用它的方法的范围内访问,并且 2 我试图制作自己的 setter setmodel 但我不知道我在做什么 :)。

最后,我在一个更容易到达的地方进行了初始化,所以我没有在其他方法中弄乱对象。这是在调用 main 时加载 table 的工作结果,稍后我可以调用更新方法重新加载它。感谢帮助的人。

public class able extends JFrame
{

//initialize here for easy access.  getmodel3() is the model getter method and 
//returns the defaultTableModel object

private static able frame =  new able();
private static JTable table = new JTable( getmodel3() );

//Start all main stuff here using the previously initialized objects.

public static void main(String[] args)
{
    JScrollPane scrollPane = new JScrollPane( table );
    frame.getContentPane().add( scrollPane );
    JPanel buttonPanel = new JPanel();
    frame.getContentPane().add( buttonPanel, BorderLayout.SOUTH );

    frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
    frame.pack();
    frame.setVisible(true);

}   

public static void update()
{
   table.setModel(getmodel3());
}

//This method makes the table model from sql result set and returns it.    
//(found online somewhere thanks to whoever wrote it)

public static DefaultTableModel getmodel3(){
    Vector<Object> columnNames = new Vector<Object>();
    Vector<Object> data = new Vector<Object>();

    try
    {
        //  Connect to an Access Database

        String url = "jdbc:sqlite:c:\sqlite3\test.db";
        Connection conn = DriverManager.getConnection(url);

        //  Read data from a table

        String sql = "Select * from Tasks";
        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery( sql );
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();

        //  Get column names

        for (int i = 1; i <= columns; i++)
        {
            columnNames.addElement( md.getColumnName(i) );
        }

        //  Get row data

        while (rs.next())
        {
            Vector<Object> row = new Vector<Object>(columns);

            for (int i = 1; i <= columns; i++)
            {
                row.addElement( rs.getObject(i) );
            }

            data.addElement( row );
        }

        rs.close();
        stmt.close();
        conn.close();
    }
    catch(Exception e)
    {
        System.out.println( e );
    }

    //  Create table with database data

    DefaultTableModel model3 = new DefaultTableModel(data, columnNames)
    {
        @Override
        public Class getColumnClass(int column)
        {
            for (int row = 0; row < getRowCount(); row++)
            {
                Object o = getValueAt(row, column);

                if (o != null)
                {
                    return o.getClass();
                }
            }

            return Object.class;
        }
    };
System.out.println("got model");

return model3;
 }

public static DefaultTableModel getmodel4(){
    Vector<Object> columnNames = new Vector<Object>();
    Vector<Object> data = new Vector<Object>();

    try
    {
        //  Connect to an Access Database

        String url = "jdbc:sqlite:c:\sqlite3\test2.db";
        Connection conn = DriverManager.getConnection(url);

        //  Read data from a table

        String sql = "Select * from Tasks";
        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery( sql );
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();

        //  Get column names

        for (int i = 1; i <= columns; i++)
        {
            columnNames.addElement( md.getColumnName(i) );
        }

        //  Get row data

        while (rs.next())
        {
            Vector<Object> row = new Vector<Object>(columns);

            for (int i = 1; i <= columns; i++)
            {
                row.addElement( rs.getObject(i) );
            }

            data.addElement( row );
        }

        rs.close();
        stmt.close();
        conn.close();
    }
    catch(Exception e)
    {
        System.out.println( e );
    }

    //  Create table with database data

    DefaultTableModel model3 = new DefaultTableModel(data, columnNames)
    {
        @Override
        public Class getColumnClass(int column)
        {
            for (int row = 0; row < getRowCount(); row++)
            {
                Object o = getValueAt(row, column);

                if (o != null)
                {
                    return o.getClass();
                }
            }

            return Object.class;
        }
    };
System.out.println("got model");

return model3;
 }


}