【发布时间】:2013-08-11 08:12:41
【问题描述】:
我有一个连接到数据库的JTable,这里的删除按钮是我的代码
用数据填充表格:
static class inventoryTableItems{
Object tempRow[];
public static DefaultTableModel itemTableModel;
inventoryTableItems() throws SQLException{
getItems();
}
public void getItems() throws SQLException{
try {
itemTableModel = new DefaultTableModel(MainFramePanels.inventory_Panels.data, MainFramePanels.inventory_Panels.Columns);
connectDB();
rows = stmtUpd.executeQuery("select c.*, q.Qty from catalogue=c inner join Quantity=q on c.SKU = q.SKU");
while(rows.next()){
tempRow = new Object[]{rows.getString(1),rows.getString(2),rows.getString(3),rows.getString(4),rows.getFloat(5),rows.getInt(6)};
itemTableModel.addRow(tempRow);
}
MainFramePanels.inventory_Panels.itemTable.setModel(itemTableModel);
MainFramePanels.mainFrame.pack();
MainFramePanels.mainFrame.revalidate();
}
catch (SQLException e) {
e.printStackTrace();
}
closeDB();
}
}
这里是删除方法代码:
static class delOldItem{
delOldItem() throws SQLException{
delItem();
}
public static void delItem() throws SQLException{
String Oprt = "DELETE";
String Dscrpt = ("Delete TYPE("+tableItemType+") ITEM("+tableItemItem+") SKU("+tableItemSKU+") SIZE("+tableItemSize+") Thick("+tableItemThick+")");
try {
connectDB();
successPanel = new JPanel();
stmtUpd.executeUpdate("DELETE from catalogue where UPPER(SKU)=UPPER('"+tableItemSKU+"')");
getLog(Username,Oprt,Dscrpt,null);
new Log();
UIManager.put("OptionPane.okButtonText", "OK");
JOptionPane.showMessageDialog(successPanel,"SUCCESSFUL", "DELETE", JOptionPane.DEFAULT_OPTION);
new inventoryTableItems();
}
catch (SQLException e) {
e.printStackTrace();
}
closeDB();
}
}
当我删除一行时,它给了我一个错误.. 哪一行不正确?这样我就不会出错了。
这是错误:
Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: -1
at java.util.Vector.elementData(Unknown Source)
at java.util.Vector.elementAt(Unknown Source)
at javax.swing.table.DefaultTableModel.getValueAt(Unknown Source)
at prgrm.MainFramePanelsAction$1.valueChanged(MainFramePanelsAction.java:36)
at javax.swing.DefaultListSelectionModel.fireValueChanged(Unknown Source)
at javax.swing.DefaultListSelectionModel.fireValueChanged(Unknown Source)
at javax.swing.DefaultListSelectionModel.fireValueChanged(Unknown Source)
at javax.swing.DefaultListSelectionModel.setLeadSelectionIndex(Unknown Source)
at javax.swing.JTable.clearSelectionAndLeadAnchor(Unknown Source)
at javax.swing.JTable.tableChanged(Unknown Source)
at javax.swing.JTable.setModel(Unknown Source)
at prgrm.Query$inventoryTableItems.getItems(Query.java:126)
at prgrm.Query$inventoryTableItems.<init>(Query.java:115)
at prgrm.Query$delOldItem.delItem(Query.java:272)
at prgrm.Query$delOldItem.<init>(Query.java:257)
at prgrm.MenuBarActions$ToolBar$1.actionPerformed(MenuBarActions.java:390)
at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.setPressed(Unknown Source)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source)
at java.awt.Component.processMouseEvent(Unknown Source)
at javax.swing.JComponent.processMouseEvent(Unknown Source)
at java.awt.Component.processEvent(Unknown Source)
at java.awt.Container.processEvent(Unknown Source)
at java.awt.Component.dispatchEventImpl(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Window.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
at java.awt.EventQueue.access$200(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)
Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: -1
at java.util.Vector.elementData(Unknown Source)
at java.util.Vector.elementAt(Unknown Source)
at javax.swing.table.DefaultTableModel.getValueAt(Unknown Source)
at prgrm.MainFramePanelsAction$1.valueChanged(MainFramePanelsAction.java:36)
at javax.swing.DefaultListSelectionModel.fireValueChanged(Unknown Source)
at javax.swing.DefaultListSelectionModel.fireValueChanged(Unknown Source)
at javax.swing.DefaultListSelectionModel.setValueIsAdjusting(Unknown Source)
at javax.swing.plaf.basic.BasicTableUI$Handler.setValueIsAdjusting(Unknown Source)
at javax.swing.plaf.basic.BasicTableUI$Handler.mouseReleased(Unknown Source)
at java.awt.AWTEventMulticaster.mouseReleased(Unknown Source)
at java.awt.Component.processMouseEvent(Unknown Source)
at javax.swing.JComponent.processMouseEvent(Unknown Source)
at java.awt.Component.processEvent(Unknown Source)
at java.awt.Container.processEvent(Unknown Source)
at java.awt.Component.dispatchEventImpl(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Window.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
at java.awt.EventQueue.access$200(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)
【问题讨论】:
-
在哪一行?你在哪里删除/?但可能是您使用的索引不正确尝试使用
jtable.convertRowIndexToModel(..) -
@nachokk 我正在删除我在表上选择的一行。当我删除它时,它给了我一个错误,这是超出范围的但是当我检查我的数据库时它被删除了。所以我想解决它给我的错误
-
如需尽快获得更好的帮助,请发帖SSCCE。
-
@John 遵循 andrew 的建议,为了获得更好的帮助,请尽快发布一个 sscce...“静态类”仅适用于嵌套类,我无法理解您的问题,您应该遵循 java 代码名称约定
-
我的代码已经太长了,并且它连接到不同的java文件...我只是问一个问题..我认为我的模型或Jtable有错误...会有如果我更新了数据库并重新运行将在没有 firetablerow 的情况下填充 JTable 的函数,则会出现错误?
标签: java swing jtable indexoutofboundsexception