将String从String更改为复选框(JTable)

Zen*_*noX 0 java swing jtable jcheckbox

我有一个小问题,即从我的数据库向JTable显示结果.它正确显示所有数据,但目前它对布尔值显示"true"或"false".

我知道这一定是因为我正在使用getString,但是有人知道要使用什么才能将其更改为复选框吗?

当前JTable:

在此输入图像描述

我的数据库:

在此输入图像描述

码:

connection con=new connection();
Connection getcon=null;
Vector col = new Vector();
Vector dat= new Vector();
ResultSet rs = null;
try{
    getcon = con.creatConnection();
    col.add("Fanta");
    col.add("Crisps");
    col.add("Beer");
    col.add("Wine");// create income table default colum names and sore it
    col.add("Water");
    col.add("Seat Row");
    col.add("Seat");
    col.add("Total Cost");  
    rs=getcon.createStatement().executeQuery("select*from orders"); //getting all the information from the table

    dat.clear();

    while(rs.next()){// if record source avilable

        Vector v =new Vector();
        v.add(rs.getString("Fanta").trim());
        v.add(rs.getString("Crisps").trim());
        v.add(rs.getString("Beer").trim());
        v.add(rs.getString("Wine").trim());// getting income values from database and store in dat
        v.add(rs.getString("Water").trim());
        v.add(rs.getString("SeatRow").trim());
        v.add(rs.getString("Seat").trim());
        v.add(rs.getString("TotalCost").trim());

        dat.add(v);
    }
    orderResults.setModel(new DefaultTableModel(dat, col));
}
catch(Exception ex){
    JOptionPane.showMessageDialog(null, ex.getMessage());
}
Run Code Online (Sandbox Code Playgroud)

Mat*_*wel 5

首先,您必须在模型中将数据保存为布尔值.所以你应该用它rs.getBoolean("Fanta")代替rs.getString("Fanta").trim().

其次,你必须覆盖你的public Class getColumnClass(int column)方法JTable.您的代码可能如下所示:

JTable orderResults = new JTable() {
    @Override
    public Class getColumnClass(int column) {
        // first 5 columns will be represented as an checkbox
        if(column <= 4){
            return Boolean.class;
        }

        // rest of them as a text
        return String.class;
    }
};
Run Code Online (Sandbox Code Playgroud)