2012-05-28 8 views
0

我在Java中創建了我的第一個應用程序(但已經用C#和Python編程),並且遇到了一個我根本無法理解的問題,因爲調試器消息對用戶非常不友好。 ;-)有史以來的第一個Java應用程序;不能在數據庫中查詢?

調試器輸出看起來像這樣:

調試:異常在線程 「AWT-EventQueue的-0」 在 Kwestionariusz.MainWindow.jButton1ActionPerformed(MainWindow.java顯示java.lang.NullPointerException: 176) 在Kwestionariusz.MainWindow.access $ 100(MainWindow.java:14)在 Kwestionariusz.MainWindow $ 2.actionPerformed(MainWindow.java:72)在 javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018) 在 javax.swing.AbstractButton $ Handler.actionPerformed(AbstractButton.java:234 1) 在 javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402) 在 javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259) 在 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)在 java.awt.Component.dispatchEvent(Component.java:4687)在 java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832) 在 java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492) 在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)在 java.awt.EventQueue.dispatchEventImpl(EventQueue.java:703)在 java.awt.EventQueue.access $ 000(EventQueue.java:102)在 的Java。 awt.EventQueue $ 3.run(EventQueue.java:662)at java.awt.EventQueue中的$ 3.run(EventQueue.java:660)在 java.security.AccessController.doPrivileged(本機方法)在 java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:76) 在 的java .security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:87) at java.awt.EventQueue $ 4.run(EventQueue.java:676)at java.awt.EventQueue $ 4.run(EventQueue.java:674)at java.security.AccessController.doPrivileged(Native Method)at java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:76) at java.awt.EventQueue.dispatchEvent(EventQueue.java:673)at java.awt。 EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:244) 在 java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:163) 在 java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:151) 在 java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:147 ) at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:139) at java.awt.EventDispatchThread.run(EventDispatchThread。Java的:97) BUILD SUCCESSFUL(總時間:16秒),

這也可能是一些與此動作:

if (("".equals(login)) || ("".equals(password)) || ("".equals(accountType))) 
     {} 
     else 
     { 
      Users user; 
      user = (Users) db.createNamedQuery("Users.findByLoginAndType") 
      .setParameter("login", login) 
      .setParameter("company", accountBool) 
      .getSingleResult(); 
      if (password.equals(user.getPassword())) 
      { 
       JFrame appWindow; 
       appWindow = new AppWindow(); 
       this.setVisible(false); 
       appWindow.setVisible(true);  
      } 
     } 

其中:

@NamedQuery(name = "Users.findByLoginAndType", query = "SELECT u FROM Users u WHERE u.login = :login AND u.company = :companyBool LIMIT 1") 
+1

你有沒有通過調試器瞭解NPE的來源? – Zavior

+0

您所看到的內容稱爲*堆棧跟蹤*。它顯示異常是在176行的MainWindow類中調用'jButton1ActionPerformed'方法拋出的。調用該方法的方法在14行,在72處由'actionPerformed'調用,等等。這是一個非常有用的工具,但您需要將其與調試器結合使用 - 您是否使用IDE? – wchargin

+0

*「有史以來的第一個Java應用程序;無法在數據庫中查詢?」*哇!我的'第一次'Java頁(每次安裝或更新開發環境時編寫)都是'HelloWorld',但'更新數據庫' - 你很勇敢。 –

回答

1

這裏就是它發生:

Kwestionariusz.MainWindow.jButton1ActionPerformed(MainWindow.java:176) at 

MainWindow.ja中的第176行VA。打開文本編輯器,打開行號顯示,然後轉到該行。查看在該行上使用的所有對象引用 - 其中一個爲空。你需要弄清楚爲什麼你沒有初始化它來指向一些有用的東西。

我個人認爲,這樣的代碼是一個巨大的錯誤:

if (("".equals(login)) || ("".equals(password)) || ("".equals(accountType))) 
     {} 

有沒有價值可言的報告,其中三個是空白的?如果一個是空的會發生什麼?如果它只有一個帶有空格的字符串呢?

我認爲你試圖在這裏表達你與用戶的合同,但是這不是用正確的習慣用法來完成的。在檢查每一個之後投擲IllegalArgumentException將是我做這件事的方式。這是一個未經檢查的例外,所以調用者將被迫處理它。

+0

我相信你沒有粘貼你所指的代碼,所以我不知道這個巨大的錯誤是什麼......但是我想你是在輸入密碼認證,而且我意識到這是錯誤的,但它只是「現在」來獲得GUI編程的所有基礎知識。 – smsware

+0

第176行是: user =(Users)db.createNamedQuery(「Users.findByLoginAndType」)。setParameter(「login」,login).setParameter(「company」,accountBool).getSingleResult();所以這只是我懷疑的地方......我仍然不知道爲什麼。我錯誤地設置了參數還是查詢錯誤? 如果用戶將字段留空,if(()||()||())就是不做事情......但我想你的方式更優雅。 – smsware

+0

我從你的代碼粘貼過,而不是與NPE有關的部分。我猜數據庫是空的。最好的方法是使用一個好的調試器並設置一箇中斷點。 – duffymo

相關問題