2014-01-27 4 views
0

У меня есть два целых числа; начало и остановка
Первоначально начало 0 и остановка 1. Как только пользователь закрывает начало окна, становится 1.Метод непрерывной работы внутри Main

У меня есть метод, который обновляет мой JTable;

private void Update_table(){ 


try{ 
    String sql ="select * from orders "; 
    pst=conn.prepareStatement(sql); 
    rs=pst.executeQuery(); 
    Table_Employee.setModel(DbUtils.resultSetToTableModel(rs)); 


} 
catch(Exception e){ 
    JOptionPane.showMessageDialog(null, e); 

} 

} 

Я хочу обновлять таблицу непрерывно, но когда я помещаю цикл while в основной метод void, программа сработает;

void main;

public static void main(String args[]) { 
    /* Set the Nimbus look and feel */ 

      //Update_table(); 
    while(start<stop) 
     new Employee_info().Update_table(); 


    //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) "> 
    /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel. 
    * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html 
    */ 
    try { 
     for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) { 
      if ("Nimbus".equals(info.getName())) { 
       javax.swing.UIManager.setLookAndFeel(info.getClassName()); 
       break; 
      } 
     } 
    } catch (ClassNotFoundException ex) { 
     java.util.logging.Logger.getLogger(Employee_info.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
    } catch (InstantiationException ex) { 
     java.util.logging.Logger.getLogger(Employee_info.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
    } catch (IllegalAccessException ex) { 
     java.util.logging.Logger.getLogger(Employee_info.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
    } catch (javax.swing.UnsupportedLookAndFeelException ex) { 
     java.util.logging.Logger.getLogger(Employee_info.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); 
    } 
    //</editor-fold> 

    /* Create and display the form */ 
    java.awt.EventQueue.invokeLater(new Runnable() { 
     public void run() { 
      new Employee_info().setVisible(true); 
     // while(1<2) 
      // rh.Update_table(); 
      // Update_table(); 
     } 
    }); 
} 

Erro;

com.mysql.jdbc.exceptions.jdbc4.MySQL SyntaxErrorException: User 12345 already has more than 'max_user_connections' active connections 

Где +12345 это имя пользователя для подключения к базе данных, это потому, что я войти в базу данных в различных классах и выполнять запросы, а?

класс связи;

import java.sql.*; 
import javax.swing.*; 

public class javaconnect { 
Connection conn=null; 

    public static Connection ConnecrDb(){ 
     try{ 
     Class.forName("com.mysql.jdbc.Driver"); 
     Connection conn = DriverManager.getConnection("jdbc:mysql://XXX.com:3306/XXX_pizza","12345 ","XXXX"); 
    // JOptionPane.showMessageDialog(null, "You got connected"); 
       return conn; 

    }catch(ClassNotFoundException | SQLException e){ 
     JOptionPane.showMessageDialog(null, e); 
     return null; 
}  

} 
} 

Класс Employee_Info вызывает класс javaconnect для установления соединения;

public Employee_info() { 
    initComponents(); 
    conn=javaconnect.ConnecrDb(); 
    Update_table(); 

} 
+0

Что говорит об ошибке? – BitNinja

+0

Просто добавлена ​​ошибка исходного вопроса. – raklar

+0

Как управляются соединения? Скорее всего, вы делаете что-то неправильно с распределением соединений. –

ответ

0

Есть несколько вещей:

1) в время цикла, как это, вы, вероятно, следует назвать Thread.sleep() в какой-то момент. 2) В этом случае, поскольку вы не спите и не получаете новое соединение каждый раз, когда вы вызываете конструктор Employee_info, вы создаете множество соединений, что, вероятно, является прямой причиной вашей ошибки. 3) У вас не должно быть бизнес-объекта, такого как Employee_info. Вместо этого, вы должны иметь ярус между (обычно называется слоем доступа к данным), с чем-то вроде этого:

public class EmployeeDao { 

    public Employee_info getEmployeeInfo(){ 
     Connection conn = getConnection(); 
     //do something with the connection, construct employee info 
     return employeeInfo 
    } 
} 

4) Вы должны использовать пул соединений, вместо инстанцирования соединения вручную. Commons-dbcp используется, обычно, обычно.

5) Следуйте соглашениям об именовании Java.

+1

... и не забудьте * закрыть * соединения ... – KarlP

Смежные вопросы