繁体   English   中英

如何使用JTable将更改的数据更新到数据库中?

[英]How to update changed data into the Database by using JTable?

Hello stackoverflow用户。

我想问几个问题。

我目前能够从数据库中获取数据并将其显示在JTable中。 另外,我想更新已在JTable中修改过的数据库中的数据,但我不知道该怎么做。 我找到了一些其他人做过的例子,但他们没有为我工作。

所以我的问题是:你如何从数据库中获取和存储数据? 我目前正在使用Array of String

public String getDBUnits  [][]; 

存储和传输数据库中的数据并将数组转换为Vector并使用a显示数据

table.setModel(new DefaultTableModel(getDBGrades,gradeHeader));

对于我的JTable。

我知道可以用来做不同的方法,但我不知道哪一个对我的情况更好。

我将非常感谢您获得一些建议或教程。

谢谢。

Ducky :)

PS如果任何人需要我用来从数据库获取数据的方法的代码,我将很乐意发布它们。

这是一个开放式问题。

对我来说,你有几个选择......

你可以...

随着表中数据的更改,实时更新数据库。

这将要求您扩展TableModel以便您可以访问setValue方法,这样您不仅可以更新模型的状态,还可以更新数据库的状态(我会更新数据库并在成功时,更新模型,但那就是我)或者将监听器附加到模型并监视适当的TableChanged事件并相应地更新数据库。

虽然这看起来是一个不错的方法,但是当数据库更新或与模型中的内容以及数据库中的内容不同步时,您可能会冒“挂”UI的风险。

你可以...

创建一个表示数据库中数据的Class 在此对象中更改值时,您只需引发一个标记该行已更改的标志。

当用户完成对表数据的更改后,他们将单击“保存”。 然后,您将遍历所有对象并确定需要更新哪些对象并将它们“保存”回数据库。

这确实有可能将“陈旧”数据写回数据库(即用户A加载数据并开始进行更改。同时用户B加载数据,进行更改并将其保存回数据库。用户A然后保存他们的更改,覆盖用户B已经提交的一些更改)

有解决这两种问题的方法,但您需要决定哪种方法最适合您当前的问题,实时或延迟更新......

更新了基本示例

首先要做的是创建一个表示数据库中数据的类。 通常,我从一个Interface开始并使用某种工厂来生成实际的实现,但是小步骤......

这有一个非常重要的变量, hasChanged 这用于标记对象需要更新...

public class Person {

    private boolean hasChanged = false;

    private String firstName;
    private String lastName;

    public Person(String firstName, String lastName) {
        this.firstName = firstName;
        this.lastName = lastName;
    }

    public boolean hasChanged() {
        return hasChanged;
    }

    public String getFirstName() {
        return firstName;
    }

    public String getLastName() {
        return lastName;
    }

    public void setFirstName(String value) {
        if (value == null ? firstName != null : !value.equals(firstName)) {
            firstName = value;
            hasChanged = true;
        }
    }

    public void setLastName(String value) {
        if (value == null ? lastName != null : !value.equals(lastName)) {
            lastName = value;
            hasChanged = true;
        }
    }
}

接下来,我们构建了一个能够建模对象列表的表模型......

public class PeopleTableModel extends AbstractTableModel {

    private List<Person> people;

    public PeopleTableModel() {
        people = new ArrayList<>(20);
    }

    public void addPerson(Person person) {
        people.add(person);
        fireTableRowsInserted(people.size() - 1, people.size() - 1);
    }

    public Person getPersonAt(int row) {
        return people.get(row);
    }

    public List<Person> getChangedPeople() {
        List<Person> changed = new ArrayList<>(people.size());

        for (Person p : people) {
            if (p.hasChanged()) {
                changed.add(p);
            }
        }

        return changed;    
    }

    @Override
    public int getRowCount() {
        return people.size();
    }

    @Override
    public String getColumnName(int column) {
        String name = null;
        switch (column) {
            case 0:
                name = "First name";
                break;
            case 1:
                name = "First name";
                break;
        }
        return name;
    }

    @Override
    public int getColumnCount() {
        return 2;
    }

    @Override
    public Object getValueAt(int rowIndex, int columnIndex) {
        Person p = people.get(rowIndex);
        Object value = null;
        switch (columnIndex) {
            case 0:
                value = p.getFirstName();
                break;
            case 1:
                value = p.getLastName();
                break;
        }
        return value;
    }

    @Override
    public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
        if (aValue instanceof String) {
            Person p = people.get(rowIndex);
            switch (columnIndex) {
                case 0:
                    p.setFirstName(aValue.toString());
                    break;
                case 1:
                    p.setLastName(aValue.toString());
                    break;
            }
            fireTableRowsUpdated(rowIndex, rowIndex);
        }
    }
}

有很多方法可以实现同样的目的,但基本上我在这里提供了一个名为getChangedPeople方法,它将返回所有已更改的People 然后,您只需循环遍历此列表并调用相应的数据库更新语句。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM