从JTable中删除行时出错

时间:2013-08-11 08:12:41

标签: java swing jtable indexoutofboundsexception

我有一个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)

1 个答案:

答案 0 :(得分:0)

在delItem()函数中,在closeDB()调用后移动跟随的位置。

new inventoryTableItems();

希望它会有所帮助。