0

我是 Java 新手,我正在练习一些新东西。我已经开始使用数据库。因此,我使用 MVC 模式制作了一个待办事项列表应用程序。

在我的模型中,我得到了所有结果。在我看来,我尝试将这些数据输出为一个漂亮的表格。问题是我没有得到任何输出,除了一段硬编码的代码..

这是我的观点的代码

JTable table = null;

public ToDoListView(ToDoListModel model) {
    this.model = model;

    setBackground(Color.WHITE);

    JTable table = new JTable();

    DefaultTableModel tableModel = new DefaultTableModel(new Object[][]{},new String[]{"To do","Date added"});

    table.setModel(tableModel);

    // this one below is outputted
    tableModel.addRow(new Object[]{"something","1-1-2012"});

    // this should give me all the results.. 
    for(int i = 0; i < model.getRows().size(); i++) {
        tableModel.addRow(model.getRows());
        System.out.println("added");
    }

    add(table);

}

在我的模型中我有这个

private Vector<String> rijen = new Vector<String>();

    public void getValue() {
    Connection con = null;
    Statement st = null;
    ResultSet rs = null;
     try {

        con = db.connectToAndQueryDatabase("test", "root", "root");
        System.out.println("connection established");

        st = con.createStatement();
        String query = "SELECT id, item, datum FROM toDoList";
        rs = st.executeQuery(query);

        while(rs.next()) {
            System.out.println(rs.getInt("id") + "\n" + rs.getString("item") + "\n" + rs.getDate("datum"));
            rijen.add(rs.getInt("id") + "");
            rijen.add(rs.getString("item"));
            rijen.add(rs.getDate("datum") + "");
        }

    public Vector<String> getRows() {
    return rijen;
}

这是所有相关代码..我不知道我错过了什么或我做错了什么。有人可以告诉我如何解决它:)吗?

4

2 回答 2

2
// This JTable attribut ...
JTable table = null;

public ToDoListView (ToDoListModel model) {
    this.model = model;
    setBackground (Color.WHITE);

    // is hidden by this local variable: 
    JTable table = new JTable();
于 2012-12-27T00:24:00.787 回答
2

在您的ToDoModel班级中,您将所有数据添加到一个大文件中Vector

    while(rs.next()) {
        System.out.println(rs.getInt("id") + "\n" + rs.getString("item") + "\n" + rs.getDate("datum"));
        rijen.add(rs.getInt("id") + "");
        rijen.add(rs.getString("item"));
        rijen.add(rs.getDate("datum") + "");
    }

然后您循环Vector将所有这些项目添加到TableModel,但该循环不正确

for(int i = 0; i < model.getRows().size(); i++) {
    tableModel.addRow(model.getRows());
    System.out.println("added");
}

您总是添加整个向量,而不仅仅是该行的数据。

将其与@user unknown 的答案结合起来,您也许可以解决您的问题

于 2012-12-27T00:27:09.360 回答