0

.size() メソッドが正しい値を返していないように見えるところに頭を悩ませることができないという奇妙なエラーがあります。

このコードの最初のビットは、ArrayList を作成します。

public void createResultList(String query) {
    ArrayList<ArrayList<String>> data = new ArrayList();

    try {
        ResultSet rs = st.executeQuery(query);
        ResultSetMetaData meta = rs.getMetaData();

        for(int i = 0; i < meta.getColumnCount(); i++) {
            data.add(i, new ArrayList<String>());
        }

        int x = 0;
        while(rs.next()) {
            for(int y = 0; y < meta.getColumnCount(); y++) {
                data.get(x).add(rs.getString(y + 1));
            }
            x++;
        }


    } catch(Exception e) {
        JOptionPane.showMessageDialog(null, e);
    }

    ResultTable result = new ResultTable(data);
    JTable table = new JTable(result);
    JScrollPane scrollpane = new JScrollPane(table);
    add(scrollpane);
    refresh();
}

これは、渡されたときにテーブルを作成するために使用される私の TableModel クラスです。

public class ResultTable extends AbstractTableModel {

    private ArrayList<ArrayList<String>> data;

    public ResultTable(ArrayList<ArrayList<String>> data) {
        this.data = data;
    }

    public int getColumnCount() { 
        return data.get(0).size(); 
    }

    public int getRowCount() { 
        return data.size();
    }

    public Object getValueAt(int row, int col) { 
        return data.get(row).get(col);
    }
}

問題は ResultTable クラスにあり、12 列の 1 つの行を返す選択クエリの場合、最初の data.get(0).size() 呼び出しは正しく 12 を返しますが、2 回目の data.size() 呼び出しは正しく返されません。 1 の代わりに 12 もあり、これは範囲外のエラーを引き起こしています。この一見逆説的な結果を誰か説明してもらえますか?

4

2 に答える 2

0

dataリストを作成するときは、各列のデータを保持するサブリストを作成します。

それが目的の場合は、結果セットの各列のデータをそれに対応するリストに追加する必要があります。

    while(rs.next()) {
        for(int y = 0; y < meta.getColumnCount(); y++) {
            data.get(y).add(rs.getString(y + 1));
        }
    }
于 2013-10-25T14:46:17.263 に答える