2015-05-12 4 views
0

Я пытаюсь вставить некоторые данные, захваченные формой gui, в мою базу данных. Когда я запускаю программу и пытаюсь добавить поставщика, я получаю исключение nullpointerexception, и мне трудно понять, почему. Любые рекомендации приветствуются.Я пытаюсь вставить значения в базу данных MySQL, получая NullPointerException

Java Метод:

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

     addVendorPanel.setVisible(true); 

     //ANDY: 
     String vendorName = addVendorNameField.getText(); 
     String customerName = addCustomerNumField.getText(); 
     String vendorCode = addVendorCodeField1.getText(); 

    String sql = "INSERT INTO VENDORS (Vendor,Cust#,Vendorcode)"+"VALUES('"+vendorName+"','"+customerName+"','"+vendorCode+"')"; 
    try { 
     openconnection(); 
     rs = statement.executeQuery(sql); 
    } catch (SQLException ex) { 
     Logger.getLogger(gui.class.getName()).log(Level.SEVERE, null, ex); 
    } 
}  

OpenConnection:

public void openconnection(){ 
    Connection conn = null; 
     try { 
     conn = DriverManager.getConnection("jdbc:mysql://sql3.freemysqlhosting.net:3306/sql376856", "xxxx","xxxxx"); 
     System.out.println("Connected database successfully..."); 
     } catch (Exception e) { 
      System.out.println(e); 
     } 
    try { 
     Statement statement = conn.createStatement(); 
    } catch (SQLException ex) { 
     Logger.getLogger(gui.class.getName()).log(Level.SEVERE, null, ex); 
    } 
} 

Объявляет глобальные переменные для использования: Сообщение

public class gui extends javax.swing.JFrame { 


Statement statement; 
Connection conn; 
ResultSet rs; 
/** 
* Creates new form gui 
*/ 
public gui() { 
    initComponents(); 
} 

Ошибка:

run: 
Connected database successfully... 
Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException 
at database.gui.addVendorToDbButtonActionPerformed(gui.java:1142) 
at database.gui.access$1300(gui.java:23) 
at database.gui$14.actionPerformed(gui.java:562) 
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022) 
at  javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2346) 
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:6527) 
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321) 
at java.awt.Component.processEvent(Component.java:6292) 
at java.awt.Container.processEvent(Container.java:2234) 
at java.awt.Component.dispatchEventImpl(Component.java:4883) 
at java.awt.Container.dispatchEventImpl(Container.java:2292) 
at java.awt.Component.dispatchEvent(Component.java:4705) 
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4898) 
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4533) 
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4462) 
at java.awt.Container.dispatchEventImpl(Container.java:2278) 
at java.awt.Window.dispatchEventImpl(Window.java:2739) 
at java.awt.Component.dispatchEvent(Component.java:4705) 
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:746) 
at java.awt.EventQueue.access$400(EventQueue.java:97) 
at java.awt.EventQueue$3.run(EventQueue.java:697) 
at java.awt.EventQueue$3.run(EventQueue.java:691) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:86) 
at java.awt.EventQueue$4.run(EventQueue.java:719) 
at java.awt.EventQueue$4.run(EventQueue.java:717) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75) 
at java.awt.EventQueue.dispatchEvent(EventQueue.java:716) 
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201) 
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116) 
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105) 
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101) 
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93) 
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82) 
+1

Что такое 1142-я линия gui.java? – Suspended

+0

rs = statement.executeQuery (sql); – user2977729

+0

Вы создали объекты для addVendorPanel, addVendorNameField, addCustomerNumField или addVendorCodeField или оператора? ? –

ответ

1

Я думаю, что ваша переменная оператора в методе addVendorToDbButtonActionPerformed имеет значение null и, следовательно, исключение nullpointer.

0
public void openconnection(){ 
     try { 
     conn = DriverManager.getConnection("jdbc:mysql://sql3.freemysqlhosting.net:3306/sql376856", "xxxx","xxxxx"); 
     System.out.println("Connected database successfully..."); 
     } catch (Exception e) { 
      System.out.println(e); 
     } 
    try { 
     statement = conn.createStatement(); 
    } catch (SQLException ex) { 
     Logger.getLogger(gui.class.getName()).log(Level.SEVERE, null, ex); 
    } 
} 

если вы идете по этому маршруту. убедитесь, что вы создали другой метод для закрытия вашего соединения.

Я также рекомендую переместить statement = conn.createStatement(); в метод, в котором вы определили свой запрос. Убедитесь, что вы закроете инструкцию и результат в этом методе после получения результатов.

+0

Есть ли другой способ создать соединение за все время работы программы? Вместо того, чтобы просто нажимать на кнопку – user2977729

+1

@ user2977729 Кэш результата соединения, поэтому, когда вы снова запросите соединение, верните тот, который вы уже открыли (проверив, имеет ли значение «null» или нет) – MadProgrammer

+0

Посмотрите вверх «Объединение соединений JDBC» – shinjw

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