将ResultSet的2D数组迭代到JTable



我有一个存储所有查询操作的结果集类。我的问题是,我试图填写一个jtable与结果集数据,但我只能在一个列中显示数据,我有三个。下面是结果集类的代码片段:

public static List<List<String>> getAllFabrics() throws SQLException{
    sql = "SELECT * FROM fabric";
    List<List<String>> values = new ArrayList<>();
    List<String> id = new ArrayList<>();
    List<String> item = new ArrayList<>();
    List<String> supplier = new ArrayList<>();
    stmt = con.createStatement();
    rs = stmt.executeQuery(sql);
    //metaData = rs.getMetaData();
    //int columnNum = metaData.getColumnCount();
    while(rs.next()){
        id.add(String.valueOf(rs.getInt("id")));
        item.add(rs.getString("ItemDesc"));
        supplier.add(rs.getString("Supplier"));
        }
    values.add(id);
    values.add(item);
    values.add(supplier);
    return values;
}

,这是我试图解决几个小时的jtable方法:

public static DefaultTableModel loadTable(){
    ModelDB model = null;
    DefaultTableModel tableModel = new DefaultTableModel();
    tableModel.addColumn("ID");
    tableModel.addColumn("Fabric");
    tableModel.addColumn("Supplier");
    try{
        List<String> id = model.getAllFabrics().get(0);
        List<String> item = model.getAllFabrics().get(1);
        List<String> supplier = model.getAllFabrics().get(2);
        //System.out.println(model.getAllFabrics().size()); tableModel.addRow(new Object[]{subRow});
        for(List<String> row:model.getAllFabrics()){
            tableModel.addRow(new Object[]{id,item,supplier});
        }

    }catch(SQLException ex){
        ex.printStackTrace();
    }
    return tableModel;
}

我找不到一种方法来迭代值以显示在各自的列中

原始回答

你就快到了!您只需要更改循环:

for(int i = 0; i < id.size(); i++) {
    tableModel.addRow(new Object[] {id.get(i),item.get(i),supplier.get(i)});
}

但是正如评论中所说,您应该考虑将数组改为行,而不是列。

编辑

这是一种方法。它与您的代码基本相同,除了行/列互换,因此该方法返回行列表,而不是列:

public static List<List<String>> getAllFabrics() throws SQLException{
    sql = "SELECT * FROM fabric";
    List<List<String>> values = new ArrayList<>();
    stmt = con.createStatement();
    rs = stmt.executeQuery(sql);
    while(rs.next()){
        List<String> row = new ArrayList<>();
        row.add(String.valueOf(rs.getInt("id")));
        row.add(rs.getString("ItemDesc"));
        row.add(rs.getString("Supplier"));
        // Now row contains {id, item, supplier}
        values.add(row);
    }
    return values;
}

然后在你的loadTable()方法中改为:

...
try{
    for(List<String> row: model.getAllFabrics()){
        tableModel.addRow(row.toArray(new String[row.size()]);
    }
...

在您的原始代码中,您多次调用model.getAllFabrics()来获取返回值。这是不好的,因为每次你这样做的方法被调用,它需要再次发出sql请求等。将返回值存储在一个变量中。在这种情况下,因为返回值只被访问一次,所以你可以像上面描述的那样做。

希望这对你有帮助

最新更新