- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
你好 stackoverflow 用户。
我想问几个问题。
我目前能够从数据库中获取数据并将其显示在 JTable 中。另外,我想更新已在 JTable 中修改的数据库中的数据,但我不知道该怎么做。我发现了一些其他人做过但对我不起作用的示例。
所以我的问题是:从数据库获取和存储数据的方式重要吗?我目前使用字符串数组
public String getDBUnits [][];
存储和传递来自数据库的数据并将数组转换为 vector 并使用
显示数据table.setModel(new DefaultTableModel(getDBGrades,gradeHeader));
用于我的 JTable。
我知道可用于执行此操作的不同方法,但我不知道哪种方法更适合我的情况。
如果能得到一些建议或教程,我将不胜感激。
谢谢。
鸭子:)
附言如果有人需要我用来从数据库中获取数据的方法的代码,我会很乐意发布它们。
最佳答案
这是一个开放式问题。
对我来说,你有几个选择......
随着表内数据的变化实时更新数据库。
这将需要您扩展 TableModel
以便您可以访问 setValue
方法,这将允许您不仅更新模型的状态,而且还更新数据库的状态(我会更新数据库,成功后更新模型,但那是我)或者将监听器附加到模型并监视适当的 TableChanged
事件并更新数据库相应地。
虽然这看起来是个不错的方法,但您冒着在更新数据库或与模型中的内容和数据库中的内容不同步时“挂起”UI 的风险...
创建一个代表数据库中数据的类
。当此对象中的值发生更改时,您只需举起一个标志,说明该行已更改。
当用户完成对表格数据的更改后,他们将单击“保存”。然后,您将遍历所有对象并确定哪些需要更新并将它们“保存”回数据库。
这确实有可能允许将“陈旧”数据写回数据库(即用户 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
。然后,您只需遍历此列表并调用适当的数据库更新语句。
关于java - 如何使用 JTable 将更改的数据更新到数据库中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16351530/
我试图理解基数排序,但在理解实现实际代码时改 rebase 数时遇到问题。这是我用来学习基数排序的代码,我会尝试解释我不明白的地方。 此代码由 GeeksForGeeks 提供: // C++ imp
话不多说,请看代码: ? 1
本文实例讲述了mysql语句实现简单的增、删、改、查操作。分享给大家供大家参考,具体如下: 1、创建db_shop数据库,如果该数据库不存在则创建 ?
使用oracle触发器 实现对某个表的增改删的监控操作,并记录到另一个表中。 代码: 复制代码代码如下: create or replace trigger test_trigge
java连接数据库增、删、改、查工具类 数据库操作工具类,因为各厂家数据库的分页条件不同,目前支持Mysql、Oracle、Postgresql的分页查询 在Postgresql环境测试过了,其他
1、修改数据 复制代码代码如下: DataRow dr =
注册表可以用来进行存储一些程序的信息,例如用户的权限、或者某些值等,可以根据个人需要进行存储和删减。 当前注册表主目录: 引用包 Wesky.Net.OpenTools 1.0.5或
是否可以将 pdf 页面的页眉更改为与当前所选书签同名的名称?我正在为我的 pdf 生成使用 Flying Saucer 。你能举个例子吗?提前致谢。 最佳答案 这对我适用于 flyingsaucer
好家伙,写后端,这多是一件美逝. 关于这个项目的代码前面的博客有写 我的第一个独立项目 - 随笔分类 - 养肥胖虎 - 博客园 (cnblogs.com
准备工作: 增、删、改、查的方法有很多很多种,这里只展示出常用的几种。 ?
需要5个类: 1.实体类:Person.java 2.抽象类:SQLOperate.java(封装了对数据库的操作) 3.助手类:DBOpenHelper.java(继承SQLiteOpenH
首先是是一个简单的例子,单链表的建立和输出。 程序1.1 复制代码 代码如下: #include<iostream> #include<string> using na
数据库操纵基本流程为: 1、连接数据库服务器 2、选择数据库 3、执行SQL语句 4、处理结果集 5、打印操作信息 其中用到的相关函数有 •resource m
我需要为 iPad 和 iPhone 设置不同颜色的标签,我知道我们可以为不同的尺寸类别更改字体大小,但是有什么方法可以根据尺寸类别的值设置不同的颜色 我知道有可用的代码解决方案,但我想知道 size
假设我有一个物体相对于相机的坐标 X、Y、Z 和方向 Rx、Ry、Rz。此外,我有这个相机在世界上的坐标 U、V、W 和方向 Ru、Rv、Rw。 如何将对象的位置(位置和旋转)转换为其在世界中的位置?
CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。如果您掌握了某框架的CRUD编写,那么意味可以使用该框架创建普通应用程序了
项目结构: 添加页面: &
本文实例讲述了android操作sqlite数据库(增、删、改、查、分页等)及listview显示数据的方法。分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识
总括 pandas的索引函数主要有三种: loc 标签索引,行和列的名称 iloc 整型索引(绝对位置索引),绝对意义上的几行几列,起始索引为0 ix 是 iloc 和 loc的合体 at
我是一名优秀的程序员,十分优秀!