从数据库中获取值时线程主java.lang.NullPointerException中的异常

波兰人

我只是想在eclipse上运行一个有问题的Java程序,但是却收到NullPointerException。我的代码发布在下面。请告诉我我做错了什么。

Rect.java

package org.spring.model;

public class Rect {

    private int id;
    private String name;

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

    public Rect(int rectId, String rectName)
    {
        setId(rectId);
        setName(rectName);
    }


}

JdbcDaoImplement.java

    package org.spring.dao;

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;

    import org.spring.model.Rect;

public class JdbcDaoImplement {

    public Rect getRect(int rectId)
    {
        Connection conn=null;

        try
        {
            Class.forName("oracle.jdbc.OracleDriver");
            String jdbcUrl = "jdbc:oracle:thin:@localhost:1521:ORCL";
            conn = DriverManager.getConnection(jdbcUrl, "system", "abcd");
            PreparedStatement ps=conn.prepareStatement("SELECT * FROM RECTANGLE WHERE id=?");
            ps.setInt(1, rectId);

            Rect rect=null;
            ResultSet rs=ps.executeQuery();
            if(rs.next()==true)
            {
                rect=new Rect(rectId,rs.getString("name"));
            }
            rs.close();
            ps.close();
            return rect;
        }
        catch(Exception e)
        {
            throw new RuntimeException();
        }
        finally
        {
            try {
                conn.close();
            } catch (SQLException e) {
                //e.printStackTrace();

            }
        }
    }

}

最后是JdbcDemo.java

package org.spring;

import org.spring.dao.JdbcDaoImplement;
import org.spring.model.Rect;

public class JdbcDemo {

    public static void main(String[] args) {
        Rect rect=new JdbcDaoImplement().getRect(1);
        System.out.println(rect.getName());
    }

}

堆栈跟踪为:

Exception in thread "main" java.lang.NullPointerException
    at org.spring.JdbcDemo.main(JdbcDemo.java:10)
肯特郡

您的main方法中很可能rect为null,然后您调用rect.getName(),然后Bang!NPE。

因为在您的getRect(int rectId)方法中,您处理了该方法中的异常,然后返回rect,如果出现问题或rs.next()错误,则将返回一个空rect对象。

您可能会考虑做的是,要么重新设计该getRect()方法,使其从不返回null,例如,如果未找到任何记录或发生异常,则抛出异常;或在您的main方法中,检查rect,确保其不为null。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

线程“主”中的java异常java.lang.NullPointerException错误

线程“主”中的异常java.lang.NullPointerException1000

线程“主”中的异常java.lang.NullPointerException?

错误:线程“主”中的异常java.lang.NullPointerException

“线程“主”中的异常java.Lang.NullPointerException”错误

在线程“主”中获取错误异常java.lang.NullPointerException

线程“主”中的异常java.lang.NullPointerException在打印Pojo值时

线程“主”中的异常java.lang.NullPointerException-HBase索引数据

Java,线程“主”中的异常java.lang.NullPointerException由于未初始化对象而导致

运行Web Scrap程序时出现“线程“主”中的异常java.lang.NullPointerException”错误

线程“主”中的异常java.lang.NullPointerException虚拟堆栈类

转换为MYSQL时Java中的线程“ main”中的异常java.lang.NullPointerException

获取错误“线程“主”中的异常java.lang.ExceptionInInitializerError”

为什么我在Java中有此异常:线程“主”中的异常java.lang.NullPointerException

“ AWT-EventQueue-0”中的异常java.lang.NullPointerException

致命异常:发布版本中的java.lang.NullPointerException

使用Jaxb unmarshal / marshal时,线程“ main”中的异常java.lang.NullPointerException

使用JNotify时在线程“主” java.lang.UnsatisfiedLinkError中获取异常

PDFbox异常-线程“主”中的异常java.lang.VerifyError

GUI中的线程“ AWT-EventQueue-0”中的异常java.lang.NullPointerException?

我的数据库中的java.lang.NullPointerException错误

线程“主”中的异常java.lang.NullPointerException com.databricks.dbutils_v1.DBUtilsHolder $$ anon $ 1.invoke

JSON解析器-写入文本文件-线程“主”中的异常java.lang.NullPointerException

从数据库中获取枚举值时出错:没有枚举常量,嵌套异常是java.lang.IllegalArgumentException

Matlab报告“线程“ AWT-EventQueue-0”中的异常java.lang.NullPointerException”

如何解决线程“ main”中的异常java.lang.NullPointerException错误

线程“ AWT-EventQueue-0”中的异常java.lang.NullPointerException登录表单错误

如何解决线程“ main”中的异常java.lang.NullPointerException

线程“ AWT-EventQueue-0”中的异常java.lang.NullPointerException For循环