gpt4 book ai didi

java - 如果记录已存在则更新 jTable 行

转载 作者:行者123 更新时间:2023-12-02 03:58:16 27 4
gpt4 key购买 nike

我正在处理发票,并已将 jTable 添加到我的多个项目的框架中,就像我有 4 个用户“项目、数量、费率、价格”字段,用户填写所有字段并单击添加按钮,然后添加这些字段到包含项目 ID 的 jTable。

现在,当用户输入相同的项目而该项目已添加到列表中并且它重复 jTable 中的行时,我面临的问题。

如果商品相同,我想更新该行,通过添加新的数量值和价格值来更新其数量字段。

 id  |Item  |qty|   rate|   Price|
--------------------------------------
12 |saee |3 | 300| 900 |

现在,如果用户输入 5 个数量的相同商品,它应该更新相同的商品或行加上数量和价格,例如。

--------------------------------------
id |Item |qty| rate| Price|
--------------------------------------
12 |saee |8 | 300| 24000|

但它不是这样,而是在 jTable 中添加了第二行。

这是我向 jTable 添加项目的代码

 DefaultTableModel model = (DefaultTableModel) tbl_sale.getModel();
model.addRow(new Object[]{lbl_id.getText(), txt_item.getText(), txt_qty.getText(), txt_rate.getText(), txt_rs.getText()});

谁能告诉我我该怎么办?

最佳答案

有时我认为我们忘记了我们是在面向对象的环境中运行以及类似的东西可以带来的力量

我的意思是,你的数据可以很容易地封装到一个对象中,例如......

public class Order {

private int id;
private String item;
private int quanity;
private double unitPrice;

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getItem() {
return item;
}

public void setItem(String item) {
this.item = item;
}

public int getQuanity() {
return quanity;
}

public void setQuanity(int quanity) {
this.quanity = quanity;
}

public double getUnitPrice() {
return unitPrice;
}

public void setUnitPrice(double unitPrice) {
this.unitPrice = unitPrice;
}

public double getTotalPrice() {
return getUnitPrice() * getQuanity();
}
}

这还能够动态计算总价,而不需要我们这样做。

DefaultTableModel 适合表示脱节的信息片段,但不太擅长表示每行的一个对象,为此,我使用 AbstractTableModel 并对其进行自定义对象的需求,例如...

public class OrderTabelModel extends AbstractTableModel {

protected static final String COLUMN_NAMES[] = {"ID", "Item", "Qty", "Rate", "Price"};
protected static final Class COLUMN_TYPES[] = {int.class, String.class, int.class, double.class, double.class};

private List<Order> orders;

public OrderTabelModel() {
orders = new ArrayList<>(25);
}

public void add(Order order) {
orders.add(order);
fireTableRowsInserted(orders.size() - 1, orders.size() - 1);
}

public void remove(Order order) {
int row = orders.indexOf(order);
if (row >= 0) {
orders.remove(order);
fireTableRowsDeleted(row, row);
}
}

public void update(Order order) {
int row = orders.indexOf(order);
if (row >= 0) {
fireTableRowsUpdated(row, row);
}
}

public Order getOrderAt(int row) {
return orders.get(row);
}

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

@Override
public int getColumnCount() {
return COLUMN_NAMES.length;
}

@Override
public Class<?> getColumnClass(int columnIndex) {
return COLUMN_TYPES[columnIndex];
}

@Override
public String getColumnName(int column) {
return COLUMN_NAMES[column];
}

@Override
public Object getValueAt(int rowIndex, int columnIndex) {
Object value = null;
Order order = getOrderAt(rowIndex);
switch (columnIndex) {
case 0:
value = order.getId();
break;
case 1:
value = order.getItem();
break;
case 2:
value = order.getQuanity();
break;
case 3:
value = order.getUnitPrice();
break;
case 4:
value = order.getTotalPrice();
break;
}
return value;
}

}

现在,当您想要添加/删除/更新给定对象时,您只需调用 add/remove/update 方法即可OrderTabelModel

但请确定,当您想要更新订单时,您正在与模型中的实例进行交互,否则事情不会按照您的预期进行......

OrderTableModel model = ...;
//...
Order order = model.getOrderAt(0);
order.setQuanity(10);
model.update(order);

关于java - 如果记录已存在则更新 jTable 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35209473/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com