java - 使用java连续两次更新Mysql行会导致错误

标签 java mysql swing

每当我连续两次更新(编辑)单行时,我都会收到此错误:

Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: -1
at java.util.Vector.elementData(Vector.java:730)
at java.util.Vector.elementAt(Vector.java:473)
at javax.swing.table.DefaultTableModel.getValueAt(DefaultTableModel.java:649)
at bicrijnmondcustomermanagement.DataView.EditActionPerformed(DataView.java:686)
at bicrijnmondcustomermanagement.DataView.access$400(DataView.java:18)
at bicrijnmondcustomermanagement.DataView$5.actionPerformed(DataView.java:366)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2341)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
at java.awt.Component.processMouseEvent(Component.java:6505)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6270)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4861)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4687)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2719)
at java.awt.Component.dispatchEvent(Component.java:4687)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:735)
at java.awt.EventQueue.access$200(EventQueue.java:103)
at java.awt.EventQueue$3.run(EventQueue.java:694)
at java.awt.EventQueue$3.run(EventQueue.java:692)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:708)
at java.awt.EventQueue$4.run(EventQueue.java:706)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:705)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)

这是有问题的代码,我尝试在网上查找但没有找到解决方案,所以我转向 StackOverflow :P 提前谢谢大家。

private void EditActionPerformed(java.awt.event.ActionEvent evt) {                                     

   try{
       int row = Table_customer.getSelectedRow();
    String TClick = (Table_customer.getModel().getValueAt(row, 0).toString());
       String edit1 = lNaam.getText();
       String edit2 = lEmail.getText();
       String edit3 = lAdres.getText();
       String edit4 = lPlaats.getText();
       String edit5 = lPostcode.getText();
       String edit6 = lTelefoon.getText();
       String edit7 = lBedrijfsNaam.getText();

       String sql="update customers set naam='"+edit1+"',email='"+edit2+"',adres='"+edit3+"',plaats='"+edit4+"',postcode='"+edit5+"',telefoon='"+edit6+"',bedrijfsnaam='"+edit7+"'where KL_NR='"+TClick+"'";
       preparedStatement=connect.prepareStatement(sql);
       preparedStatement.execute();
    JOptionPane.showMessageDialog(null, "Updated");
   TheRefresher();


   }catch(SQLException | HeadlessException e){
   JOptionPane.showMessageDialog(null, e);
   }finally {
try{ //Update_tableCustomers();
resultSet.close(); preparedStatement.close(); }
catch(Exception e) { } }


}                     

诗。此外,如果我编辑另一行并返回到之前编辑的行,它工作得很好,当我连续编辑同一行两次时,就会出现问题。

最佳答案

您可能在此操作之前没有选择任何行。

private void EditActionPerformed(java.awt.event.ActionEvent evt)        
{                                     

  try{
   int row = Table_customer.getSelectedRow();
   System.out.println("selected row : " + row);
   if(row < 0) {
      JOptionPane.showMessageDialog(parentDialog, "Must select row" ); 
      return;
   }
    ...
 }

关于java - 使用java连续两次更新Mysql行会导致错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19294347/

相关文章:

java - 此方法必须返回 boolean 类型的结果,java

mysql - 如何显示我们在两个表的内连接中获得的行中的列差异

java - 如何在 GridBagLayout 中左对齐组件?

从 Eclipse 运行 ant 时出现 javac : java. lang.OutOfMemoryError

java - 在 Java 中,当使用移位时,为什么 1 << 32 != 1 << 31 << 1?

java - 在 Android 中使用 Timer.scheduleAtFixedRate()

android - Mysql在Android应用中没有得到完美的结果

mysql - SQL 语句 - 选择此查询的逆语句

java - Swing、Java 和多线程以及着色按钮

java - JList 文本对齐