如何将 DefaultTableModel 对象的数据放入 DefaultTableModel 的子类中

How to get a DefaultTableModel object's data into a subclass of DefaultTableModel

我有一个 jTable 显示简单的两列 sql table 的数据并允许用户维护列表。这是我的第一个 java 程序。让用户可以编辑数据列表并按保存更新。 我从这行代码中获取 sql 数据到 jTable 的 DefaultTableModel:

paCutAboveTable.SetTableModel((DefaultTableModel) DbUtils.resultSetToTableModel(rs));

我猜这里的人很熟悉 DBUtils 和 resultSets。 我想在每一行中添加一个复选框。在这里和其他地方看,我一直看到子类化 DefaultTableModel 以便覆盖这样的方法:

/*

  * JTable uses this method to determine the default renderer/
  * editor for each cell.  If we didn't implement this method,
  * then the last column would contain text ("true"/"false"),
  * rather than a check box.
  */

 public Class getColumnClass(int c) {

     return getValueAt(0, c).getClass();
   }

但是我不知道如何将 DefaultTableModel 的输出从 resultSetToTableModel 方法获取到我的子类 - 如果将 SetTableModel 方法更改为接受子类作为其参数,则显示的语句不会编译。 有没有我想念的简单方法?

下面是一个示例,展示了如何从 ResultSet 中读取数据并在您自己的自定义 DefaultTableModel 中实现 getColumnClass(...) 方法:

import java.awt.*;
import java.sql.*;
import java.util.*;
import javax.swing.*;
import javax.swing.table.*;

public class TableFromDatabase extends JFrame
{
    public TableFromDatabase()
    {
        Vector<Object> columnNames = new Vector<Object>();
        Vector<Object> data = new Vector<Object>();

        try
        {
            //  Connect to an Access Database

            String driver = "sun.jdbc.odbc.JdbcOdbcDriver";
//            String url = "jdbc:odbc:???";  // if using ODBC Data Source name
            String url =
                "jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=c:/directory/???.mdb";
            String userid = "";
            String password = "";

            Class.forName( driver );
            Connection connection = DriverManager.getConnection( url, userid, password );

            //  Read data from a table

            String sql = "Select * from ???";
            Statement stmt = connection.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.getColumnLabel(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();
            connection.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;
            }
        };

        JTable table = new JTable( model );
        JScrollPane scrollPane = new JScrollPane( table );
        add( scrollPane );

        JPanel buttonPanel = new JPanel();
        add( buttonPanel, BorderLayout.SOUTH );
    }

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

通过覆盖 getColumnClass(...) 方法,您现在将看到右对齐格式的数字,如果您需要对数据进行排序,它将正常工作,因为该列将根据数值而不是字符串值进行排序.

I want to add a CheckBox to each row.

现在你有两个选择:

  1. 修改上面的代码,使"columnNames" Vector包含复选框列的另一个header名称,并向每个"row"添加Boolean.FALSE遍历 ResultSet 时的向量。

  2. 按原样使用上面的 TableModel(或使用 DbUtils TableModel),然后创建一个包装器 TableModel,它将向任何现有 TableModel 添加一个复选框列。查看:How to add checkbox in Jtable populated using rs2xml 了解此方法的示例。