第一个Java应用程序;无法在数据库内查询?

时间:2012-05-28 19:35:16

标签: java mysql

我用Java创建了我的第一个应用程序(但是已经用C#和Python编程)并且遇到了一个我甚至无法理解的问题,因为调试器消息对用户不友好。 ; - )

调试器输出如下所示:

  

debug:线程“AWT-EventQueue-0”中的异常   java.lang.NullPointerException at   Kwestionariusz.MainWindow.jButton1ActionPerformed(MainWindow.java:176)     在Kwestionariusz.MainWindow.access $ 100(MainWindow.java:14)at   Kwestionariusz.MainWindow $ 2.actionPerformed(MainWindow.java:72)at at   javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018)     在   javax.swing.AbstractButton中的$ Handler.actionPerformed(AbstractButton.java:2341)     在   javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)     在   javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)     在   javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)     在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)     在   java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)     at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)     在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:703)at at   java.awt.EventQueue.access $ 000(EventQueue.java:102)at   java.awt.EventQueue $ 3.run(EventQueue.java:662)at   java.awt.EventQueue $ 3.run(EventQueue.java:660)at   java.security.AccessController.doPrivileged(Native Method)at   java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:76)     在   java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:87)     在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)     在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)     在   java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:139)     at java.awt.EventDispatchThread.run(EventDispatchThread.java:97)   建立成功(总时间: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 个答案:

答案 0 :(得分:1)

以下是它发生的地方:

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

MainWindow.java中的第176行。打开文本编辑器,打开行号显示,然后转到该行。查看在该行上使用的所有对象引用 - 其中一个为null。你需要弄清楚为什么你没有初始化它以指向有用的东西。

就个人而言,我认为像这样的代码是一个巨大的错误:

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

在报告这三个中哪一个是空白时,根本没有价值吗?如果一个为空,会发生什么?如果它只有一个带空格的字符串怎么办?

我认为你试图在这里与用户表达你的合同,但是没有使用正确的习惯用法。在检查每一个之后投掷IllegalArgumentException将是我这样做的方式。这是一个未经检查的异常,因此调用者将被迫处理它。