- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我尝试在运行时在 JTable
中添加行,数据成功来自数据库,但行未添加到 JTable
中。我已经尝试了很多来自 stackoverflow 的解决方案,但没有取得任何成功。
这是我的代码:
DefaultTableModel model = new DefaultTableModel(new String[]{ "Invoice Number", "Consignee's Name", "Invoice Date", "Amount" }, 0);
void setLabel(String s1,String s2) {
JOptionPane.showMessageDialog(this, "You Choose Invoice List of Period "+s1+" to "+s2, "Success", JOptionPane.INFORMATION_MESSAGE);
try {
Class.forName("com.mysql.jdbc.Driver");
java.sql.Connection con = DriverManager.getConnection ("jdbc:mysql://localhost:3306/resetdb", "root", "");
java.sql.Statement stmt = con.createStatement();
ResultSet rs = null;
String SQL;
SQL="Select * from bill_info where invdt BETWEEN '"+s1+"' AND '"+s2+"'";
rs = (ResultSet) stmt.executeQuery(SQL);
if (rs.next()) {
rs.beforeFirst();
while(rs.next()) {
count++;
String d = rs.getString("invoice");
String e = rs.getString("Cname");
String f = rs.getString("invdt");
String g = rs.getString("Amount");
model.addRow(new Object[]{ d,e,f,g });
}
}
}
catch(Exception e) {
JOptionPane.showMessageDialog(this,e.getMessage());
}
}
函数setLabel(String s1, String s2)
是从上一帧调用的,我将String
格式的2个日期作为其参数传递。我的任务是打印所选期间内的所有发票数据。
为了检查,我又尝试了一件事。我在 model.addRow(new Object[]{ d,e,f,g });
之前在代码中添加了以下几行,以检查数据是否成功检索以及是否在输出中成功打印数据:
System.out.println(d);
System.out.println(e);
System.out.println(f);
System.out.println(g);
最佳答案
是setLabel()
从 Swing 事件调度线程调用?如果不是,这可能会导致问题,因为大多数 Swing 组件只能在 EDT 上更新。
如果setLabel()
从 EDT 调用,那么您会遇到另一个问题:连接到数据库并在 EDT 中执行长时间运行的任务,这可能会锁定您的 UI。相反,您应该使用 SwingWorker<>
访问数据库。
Minimal Complete Verifiable Example :
public class TableTest {
public static void main(String[] args) {
SwingUtilities.invokeLater(TableTest::new);
}
private final static String[] COLUMNS = { "x", "x^2", "x^3", "x^4" };
DefaultTableModel model = new DefaultTableModel(COLUMNS, 0);
TableTest() {
JFrame frame = new JFrame("Table Test");
frame.setSize(600, 300);
frame.setLayout(new BorderLayout());
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JTable tbl = new JTable(model);
frame.add(new JScrollPane(tbl), BorderLayout.CENTER);
JPanel btns = new JPanel();
frame.add(btns, BorderLayout.PAGE_START);
btns.add(new JButton(fillTable));
frame.setVisible(true);
}
@SuppressWarnings("serial")
Action fillTable = new AbstractAction("Fill Table") {
@Override
public void actionPerformed(ActionEvent e) {
fillTable.setEnabled(false);
Query query = new Query();
query.execute();
}
};
class Query extends SwingWorker<Void, String[]> {
@Override
protected void process(List<String[]> chunks) {
for (String[] row : chunks) {
model.addRow(row);
}
}
@Override
protected Void doInBackground() throws Exception {
for (int i = 0; i < 10; i++) {
Thread.sleep(400); // Slow database retrieval :-)
String[] row = new String[4];
row[0] = Integer.toString(i);
row[1] = Integer.toString(i * i);
row[2] = Integer.toString(i * i * i);
row[3] = Integer.toString(i * i * i * i);
publish(row);
}
return null;
}
@Override
protected void done() {
fillTable.setEnabled(true);
}
}
}
关于java - java中的行未添加到JTable中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41498337/
我已经多次看到我的问题被问到,但我从未看到我期望的答案。我已经在 JTable 中输入了数据库的元素,并且我希望能够通过一些 JButtons 删除/添加元素。问题是当我添加/删除时,修改在数据库
我正在使用 JTable 做一个项目,我想让我的表格单元格可编辑。我用过, public boolean isCellEditable(int row, int column) {
我正在编写一个应用程序包,其中包含一个主类,其中主方法与GUI类分开,GUI类包含一个带有jtabbedpane的jframe,它有两个选项卡,第一个选项卡包含一个jtable,称为jtable1,第
我制作了一个表格来将 Arraylist 中的数据加粗,但如果我删除该数据,我会希望该表格更新并取消对 Arraylist 中加粗的单元格的粗体显示。我该怎么做呢?或从另一个类关闭该类的实例 最佳答案
如果我的 JTable 的列未按字母顺序排列,我可以使用 getSelectedRows() 并毫无问题地获取它们的行的值。但是,如果用户单击列名并且行在该列中按字母顺序排列,则 getSelecte
我有一个 JTable,用户可以在其中在单元格中输入数据。然后有一个“保存”按钮,用于收集表格数据,将其格式化为 csv,并将其保存到文件中。 但是,如果用户将最后编辑的单元格保留在选定状态,并单击“
我编写了下面的代码,以便在当前 JTable 上进行选择时创建一个新的 JTable: makeTbale.addActionListener(new ActionListener() { pub
我正在使用 Swing 编写 Java 应用程序。我有两个表,我必须将内容从一个表复制到另一个表(复制)。问题是,如果我清除目标表行,那么我的源表行也会被删除。 如果我按 CopyAll,那么我会将
我一直致力于JTable,我的项目: 从数据库读取数据(我完成了这个任务并能够在JTable中显示)。 然后将数据按子组显示并保存到文件(文本/Excel)中。 我有 JTable 的基本知识,并且使
我有以下类(class): public class customer_master extends javax.swing.JInternalFrame { Connection con =
您好,我是 JAVA 的新手,在学习时正在开发 GUI。我创建了一个带有 ScrollPane 和 JTable 的 JFrame。当我增加 2 列以上时,第一行下方的数据不会显示。 此外,当我的 J
我正在进行项目的最后一部分,这是我遇到的最后问题之一。这部分用于编辑预订,即更改为特定预订预订的房间。我有 2 个 JTable,其中一个有可用房间,另一个有已预订的房间。两者都有单独的 Defaul
我有 2 个 JTable,我需要从表 2 中复制特定列(包括该列中的所有数据)并将其添加到表 1 中的下一个空闲列中。有人知道执行此操作的最佳方法吗? 谢谢 最佳答案 DefaultTableMod
美好的一天!我在 Jtable 方面遇到了困难。我已经阅读和浏览了各种教程,但我不太明白它的要点。我的问题是,我必须从 jtable (jTable1) 中选择包含 (ClientID、LastNam
我的 SERVER 表单上有一个 JTable,它是从 MySQL 数据库填充的,在构造函数中编码: String sql = "SELECT * from fiekorari"; t
我在我的项目上工作,我需要将一行从 JTable 复制到另一个 JTable,第二个 JTable 应该只是单行表。我为第一个 JTable 创建了 mouselistener,双击它应该复制行并将其
我有这段代码可以完全按预期工作 package com.grantbroadwater.signInAssistant.view; import java.awt.BorderLayout; impo
我有一个列表人员(在 jTable 中)并想将其导出到 excel 文件我需要每个人转到单独的工作表所以我需要拆分原始 jTable,但我不知道如何? 这就是我想做的? public void exp
我有一个包含 7 列和 2 行的 JTable。在我的 JTable 下方,我有一个 JTextField。当我在 JTextField 中输入内容时,我可以很容易地得到我输入的内容:String l
我正在尝试将一个 JTable 嵌套在另一个 JTable 的列中(使用 CellRenderer)。 示例(错误)输出: 为什么下面的例子没有输出表中表? import java.awt.Compo
我是一名优秀的程序员,十分优秀!