将ResultSet的2D数组迭代为JTable

时间:2016-10-11 07:29:52

标签: java mysql arraylist 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;
}

我无法找到迭代值以在各自列中显示的方法。

1 个答案:

答案 0 :(得分:1)

原始回答

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

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请求等。将返回值存储在变量中。在这种情况下,虽然只有在你可以按照我上面描述的方式进行后才能访问返回值。

希望这会有所帮助:)