如何使用JCheckboxes为每行添加新列到JTable中

时间:2016-08-28 10:09:09

标签: java mysql swing jdbc

我想要一个有三列的Jtable,其中从数据库中选择两列,第三列需要为每行设置JcheckBox

我有这样的代码

    DefaultTableModel model = new DefaultTableModel();
    model.setColumnIdentifiers(columns);

    table = new JTable();
    table.setModel(model);
    table.setAutoResizeMode(JTable.AUTO_RESIZE_ALL_COLUMNS);
    table.setFillsViewportHeight(true);
    JScrollPane scroll = new JScrollPane(table);

    TableColumn tc = table.getColumnModel().getColumn(2);
    tc.setCellEditor(table.getDefaultEditor(Boolean.class));         
   tc.setCellRenderer(table.getDefaultRenderer(Boolean.class));
    frame.getContentPane().add(scroll);

    String col_1 = "";
    Integer col_2 = 0;

 try
  {
   ////DefaultTableModel default_model = new DefaultTableModel();
  ////default_model.setColumnIdentifiers(columns);
  ((DefaultTableModel) model).setColumnIdentifiers(columns);
  Class.forName("com.mysql.jdbc.Driver").newInstance();
  Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/hdb","root","root");

  Statement stmnt = con.createStatement();

  java.sql.ResultSet rs=stmnt.executeQuery("select col_1,col_2 from databaseTable");

        while(rs.next()) 
        {
            act_name = rs.getString("col_1");
            time_in_min = rs.getInt("col_2");
            model.addRow(new Object[]{col_1,col_2,new Boolean(false)});
            //////((DefaultTableModel) model).addRow(new Object[]{col_1,col_2, Boolean.FALSE});

        }

        con.close();

    }catch(Exception e)
    {
        e.printStackTrace();
    }

}

它只为列赋值为false而不是复选框

1 个答案:

答案 0 :(得分:1)

覆盖以返回正确的列类

db = SqlAlchemy(app)

并将其用作桌面模型。
这些行

class MyTableModel extends DefaultTableModel{

    public Class<?> getColumnClass(int columnIndex) {
        return getValueAt(0, columnIndex).getClass();
    }
}

不需要。