- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在里面做了一个java程序,我有2个jlists(主类别和子类别)和一个从mysql数据库检索值的jtable,在jtable中有一个额外的复选框列,当用户选择几行和从 jlists 选择值,然后自动更新 jtable 中的 2 列(主类别和子类别),我面临的问题是,第一次选择几行并更新它时工作正常,但是当您选择几个不同的行和更新比它更新您之前选择的行和您刚刚选择的行那么我该如何解决这个问题?请帮忙
我的代码:
//Import Statements
import java.awt.EventQueue;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JOptionPane;
import javax.swing.JTable;
import javax.swing.JScrollPane;
import javax.swing.ListSelectionModel;
import javax.swing.table.DefaultTableModel;
import javax.swing.JLabel;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.awt.Font;
import java.awt.Color;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.sql.PreparedStatement;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.security.auth.Refreshable;
import javax.swing.JCheckBox;
import javax.swing.JComboBox;
import javax.swing.JTextField;
import net.proteanit.sql.DbUtils;
public class stock extends JFrame implements MouseListener {
Object selectedCellValue[] = new Object[50];//Variable for selecting cell in JTable
static Connection connection = null;//Connects to sql
static Statement stmt = null;//Makes sql query or statement
static ResultSet rs = null;//gets results from the query
JLabel lblDate;
JLabel lblUpdateStock;
JLabel lblcategory;
JLabel lblSubcategory;
JTextField txtPartNo;
int selectedRow[] = new int[5000];//variable which stores selected row in a table
static int index = 0;
static JTable table;
JList main_list;//Main category
JList sub_list;//Sub category
JScrollPane scrollPane_1;
private static String[] categories = {"Accessories", "Boxed Accessories", "Cordless", "Demolition", "Drilling", "Dust Extraction Accessories", "Garden / Agriculture Tools", "Grinding", "Grinding / Cutting", "Nibblers", "Petrol Engine Tools", "Planing", "Rotary / Demolition", "Rotary Drilling", "Routing", "Routing / Planing", "Sanding / Polishing", "Sawing", "Screwdriving", "Shears"};
private static String[] sub_categories = {"Abrasive Belt", "Abrasive Disc / Pad", "Abrasive Paper", "Abrasive Wheels", "Accessories", "Accessories for Core Cutters", "Adapter / Drill Chuck / Dust bag", "Adapters / Battery Holder / Bulb", "Band Saw Blades and Accessories", "Battery / Charger Reference Chart", "Battery Chargers", "Belt Sander Accessories", "Broach Cutter for Magnetic Drilling Machine", "Brush and Dust bag", "Brush Cutter Accessories", "Chain Mortiser Accessories", "Chisels", "Combination Sets", "Core Bits", "Core Cutters", "Cut-out Tool Accessories", "Cutting metal", "Diamond Polishing Pad", "Drill Bits", "Drill Bits / Chisels", "Drill Bits / Holesaws", "Drill Chuck", "Drill Chucks / Angle Attachment", "Drill Stand", "Driver Drills / Bit Sets", "Dust Bag", "Dust Cover / Bag", "Extension Bar / Universal Joint / Adapters / Assembly", "Filters", "Flanges", "Glass and Tiles", "Grip", "Grip / Trolley", "Grip/ Loop Handle / Wrenches", "Guide Rule / Guide Rail", "Hammer Service Kits / Oil supply", "Hedge Trimmer Blades", "Hole saw", "Hook and Oil", "Hoses & Pipes", "Impact Sockets", "Jig Saw Accessories", "Jig Saw Blades", "Lawn Mower Blades", "Lithium-ion Batteries", "Maccess Accessories Set", "Masonry", "Masonry, Concrete", "Metal", "Mixing Blades", "Ni-Cd Batteries", "Nibbling Accessories", "Nozzles", "Oil / Grip", "Other Accessories", "Other Blades", "Other Blades & Rings", "Pad", "Petrol Blower Accessories", "Philips Bits", "Philips Bits Holder / Socket Bits", "Planner Accessories", "Plate Joiner Accessories", "Reciprocating Saw Blades", "Router Bits", "Router Bits / Impact Sockets", "Scroll Saw Blades", "Shearing Accessories", "Slide Compound / Miter Saw Accessories", "Slotted Bits", "Specialized Blades", "System Charts", "Table and Stand", "Table Saw Accessories", "Thin Cutting Wheels", "Trimmer, Router, Sash Router Accessories", "Wood", "Wood Cutting"};
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
stock frame = new stock();
frame.setVisible(true);
}
});
}
/**
* Create the frame.
*/
public stock() {
getContentPane().setBackground(new Color(176, 224, 230));
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 664, 698);
setResizable(false);
setLocationRelativeTo(null);
getContentPane().setLayout(null);
// Customer List
ImageIcon titleIcon = new ImageIcon("C:\\Users\\Samir\\Desktop\\banner.jpg");
lblUpdateStock = new JLabel(titleIcon);
lblUpdateStock.setFont(new Font("Castellar", Font.BOLD, 28));
lblUpdateStock.setBounds(0, 0, 658, 111);
getContentPane().add(lblUpdateStock);
JLabel lblPartNo = new JLabel("Part No :");
lblPartNo.setFont(new Font("Bookman Old Style", Font.PLAIN, 16));
lblPartNo.setBounds(20, 132, 70, 14);
getContentPane().add(lblPartNo);
txtPartNo = new JTextField();
txtPartNo.setBounds(100, 127, 172, 24);
getContentPane().add(txtPartNo);
txtPartNo.setColumns(10);
lblcategory = new JLabel("Main Category");
lblcategory.setFont(new Font("Calisto MT", Font.PLAIN, 16));
lblcategory.setBounds(103, 173, 127, 24);
getContentPane().add(lblcategory);
lblSubcategory = new JLabel("Sub Category");
lblSubcategory.setFont(new Font("Bookman Old Style", Font.PLAIN, 16));
lblSubcategory.setBounds(432, 173, 107, 24);
getContentPane().add(lblSubcategory);
// ScrollPane
JScrollPane scrollPane2 = new JScrollPane();
scrollPane2.setBounds(20, 480, 617, 154);
getContentPane().add(scrollPane2);
// Table
table = new JTable();
scrollPane2.setViewportView(table);
// Button Update
JButton btnUpdate = new JButton("update");
btnUpdate.setBounds(274, 439, 107, 30);
btnUpdate.setFont(new Font("Copperplate Gothic Bold", Font.PLAIN, 18));
btnUpdate.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
try {
UpdateData();
PopulateData();
} catch (SQLException ex) {
Logger.getLogger(stock.class.getName()).log(Level.SEVERE, null, ex);
}
}
});
getContentPane().add(btnUpdate);
JScrollPane scrollPane = new JScrollPane();
scrollPane.setBounds(20, 202, 287, 226);
getContentPane().add(scrollPane);
main_list = new JList(categories);
scrollPane.setViewportView(main_list);
main_list.setFont(new Font("Simplified Arabic Fixed", Font.PLAIN, 15));
main_list.setVisibleRowCount(3);
main_list.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
scrollPane_1 = new JScrollPane();
scrollPane_1.setBounds(336, 202, 301, 226);
getContentPane().add(scrollPane_1);
sub_list = new JList(sub_categories);
scrollPane_1.setViewportView(sub_list);
sub_list.setFont(new Font("Simplified Arabic Fixed", Font.PLAIN, 15));
sub_list.setVisibleRowCount(3);
sub_list.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
PopulateData();
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
if (e.getClickCount() == 1) {
JTable target = (JTable) e.getSource();
selectedRow[index] = target.getSelectedRow();
int selectedColumn = 0;
selectedCellValue[index] = target.getValueAt(selectedRow[index], selectedColumn);
index++;
}
}
});
}
private static void PopulateData() {
// Clear table
table.setModel(new DefaultTableModel());
// Model for Table
DefaultTableModel model = new DefaultTableModel() {
public Class<?> getColumnClass(int column) {
switch (column) {
case 0:
return String.class;
case 1:
return String.class;
case 2:
return String.class;
case 3:
return String.class;
case 4:
return Boolean.class;
default:
return String.class;
}
}
};
table.setModel(model);
// Add Column
// model.addColumn("Select");
model.addColumn("product_code");
model.addColumn("description");
model.addColumn("main_category");
model.addColumn("sub_category");
model.addColumn("Select");
Connection con = null;
Statement s = null;
try {
//Change this
// Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
// con = DriverManager.getConnection("jdbc:odbc:Project");
try{
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
con = DriverManager.getConnection("jdbc:mysql://192.168.1.254/asser_old?user=&password=");
s = con.createStatement();
String sql = "SELECT product_code, description, main_category,sub_category FROM stock";
ResultSet rec = s.executeQuery(sql);
int row = 0;
while ((rec != null) && (rec.next())) {
model.addRow(new Object[0]);
model.setValueAt(false, row, 4); // Checkbox
model.setValueAt(rec.getString("product_code"), row, 0);
model.setValueAt(rec.getString("description"), row, 1);
model.setValueAt(rec.getString("main_category"), row, 2);
model.setValueAt(rec.getString("sub_category"), row, 3);
row++;
}
} catch (Exception e) {
// TODO Auto-generated catch block
JOptionPane.showMessageDialog(null, e.getMessage());
e.printStackTrace();
}
}
private void UpdateData() throws SQLException {
Connection connect = null;
Statement s = null;
ResultSet rs = null;
try{
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
connect = DriverManager.getConnection("jdbc:mysql://192.168.1.254/asser_old?user=&password=");
System.out.println("Connected");
s = connect.createStatement();
String part = "";
String partno = txtPartNo.getText().toString();
String Descrip = "";
String cat = "";
String subcat = "";
String category = main_list.getSelectedValue().toString();
String sub_category = sub_list.getSelectedValue().toString();
String query = "Select description,main_category,sub_category from stock where product_code ='" + partno + "'";
stmt = connect.createStatement();
rs = stmt.executeQuery(query);
while (rs.next()) {
Descrip = rs.getString("description");
cat = rs.getString("main_category");
subcat = rs.getString("sub_category");
}
String query2 = "UPDATE stock SET main_category='" + category + "',sub_category='" + sub_category + "' where product_code ='" + partno + "'";
stmt.executeUpdate(query2);
System.out.println("Updated");
txtPartNo.setText("");
txtPartNo.requestFocus();
System.out.println(selectedCellValue[index]);
for (int count = 0; count < index; count++) {
String sql = "select * from stock where product_code = '" + selectedCellValue[count] + "' ";
rs = s.executeQuery(sql);
String sql2 = "UPDATE stock SET main_category='" + category + "',sub_category='" + sub_category + "' where product_code = '" + selectedCellValue[count] + "'";
s.executeUpdate(sql2);
}
}
@Override
public void mousePressed(MouseEvent e) {
}
@Override
public void mouseReleased(MouseEvent e) {
}
@Override
public void mouseEntered(MouseEvent e) {
}
@Override
public void mouseExited(MouseEvent e) {
}
@Override
public void mouseClicked(MouseEvent arg0) {
}
}
最佳答案
例如,一个基本想法是将表/模型中的数据重置回false
..
for (int row = 0; row < table.getRowCount(); row++) {
if (table.getValueAt(row, 4) == Boolean.TRUE) {
table.setValueAt(Boolean.FALSE, row, 4);
}
}
仔细看看How to Use Tables了解更多详情
已更新
摆脱selectedCellValue
,这只是令人困惑的事情。
只需使用类似上面的内容即可构建所选项目的List
List<Integer> selectedRows = new ArrayList<>(25);
for (int row = 0; row < table.getRowCount(); row++) {
if (table.getValueAt(row, 4) == Boolean.TRUE) {
selectedRows.add(row);
}
}
然后类似...
for (int row : selectedRows) {
int code = table.getValueAt(row, 0);
String sql = "select * from stock where product_code = '" + code + "' ";
// Blah, blah, blah...
获取所选行所需的值。当然,您可以结合这两种想法并使用单个循环......
您的数据库资源处于危险的无人管理状态,这可能会降低应用程序的性能,并导致数据库服务器在这些资源的使用生命周期之外维持开放连接。
看看The try-with-resources Statement关于如何更好地管理资源的一些想法。请记住,如果您打开它,则必须将其关闭。
您还迫切需要了解 Using Prepared Statements
关于java - 从 jlist 中选择并使用复选框更新 jtable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28316853/
我已经多次看到我的问题被问到,但我从未看到我期望的答案。我已经在 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
我是一名优秀的程序员,十分优秀!