当前位置: 首页 > 知识库问答 >
问题:

当我尝试从Mysql基中选择数据时,出现NullPointerException

白子明
2023-03-14

我有麻烦了。当我尝试从数据库中选择数据时,我看到错误NullPointerException。为了连接到数据库,我使用了单例模式。

public class Database {

private static Database instance = new Database();

private Connection con;

private Database() {

}

public static Database getInstance() {
    return instance;
}

public Connection getConnection(){
    return con;
}
public void connect() throws Exception {

    if (con != null)
        return;

    try {
        Class.forName("com.mysql.jdbc.Driver");
    } catch (ClassNotFoundException e) {
        throw new Exception(e);
    }

    String url = String.format("jdbc:mysql://127.0.0.1:3306/newssystem");

    con = DriverManager.getConnection(url, "root","");
}

public void disconnect() {
    if (con != null) {
        try {
            con.close();
        } catch (SQLException e) {
            System.out.println("Nie można zakończyć połączenia");
        }
    }

    con = null;
}

}
    ArrayList<Artykul> news = new ArrayList<Artykul>();

    Connection conn = Database.getInstance().getConnection();

    String sql = "SELECT id, title, article FROM news";

    Statement pa = conn.createStatement();

    ResultSet results = pa.executeQuery(sql);

    while(results.next()) {                                     
        int id = results.getInt("id");
        String title = results.getString("title");
        String article = results.getString("article");
        Artykul artykul = new Artykul(id, title, article);  
        news.add(artykul);
    }
    results.close();
    pa.close();
    return news;
}
}
    combo.setBounds(150, 250, 350, 30);
    combo.removeAllItems();
    System.out.println("poza  pętlą");
    this.add(combo);

    ArrayList<Artykul> artykul = new ArrayList<Artykul>();
    artykul = art.getArtykul();


    String[] aa = new String[artykul.size()];
    for(int i =0; i<artykul.size(); i++){
         aa[i] = artykul.get(i).getTitle();
    }


Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
 at model.ArtOpcje.getArtykul(ArtOpcje.java:40)
 at view.View.<init>(View.java:82)
 at aplication.Aplication.runApp(Aplication.java:34)
 at aplication.Aplication$1.run(Aplication.java:21)
 at java.awt.event.InvocationEvent.dispatch(Unknown Source)
 at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
 at java.awt.EventQueue.access$500(Unknown Source)
 at java.awt.EventQueue$3.run(Unknown Source)
 at java.awt.EventQueue$3.run(Unknown Source)
 at java.security.AccessController.doPrivileged(Native Method)
 at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
 at java.awt.EventQueue.dispatchEvent(Unknown Source)
 at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
 at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
 at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
 at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
 at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
 at java.awt.EventDispatchThread.run(Unknown Source)

此处为NullPointerException:

Statement pa = conn.createStatement();

共有1个答案

欧阳山
2023-03-14

如果仔细查看代码,就会发现connection对象在connect方法内部是initialize。但在代码中从不调用该方法。因此调用

Connection conn = Database.getInstance().getConnection();

将返回connection对象的空实例。相反,您应该使用以下代码

Database db = Database.getInstance();
db.connect();
db.getConnection();

这应该能解决你的问题。

注意:在理想情况下,您应该利用连接池或数据源,而不是编写自己的JDBC代码。

 类似资料:
  • 我目前正在制作一个WordPress插件,并试图从WooCommerce数据库中选择几个值,我一直得到的是同一个错误。什么可能是错的? 我的代码: 错误: 致命错误:未捕获错误:调用C:\xampp\htdocs\ExamenProject\wp content\plugins\drukkebaasjes sizedata\drukkebaasjes sizedata.php中未定义的方法mysq

  • 本文向大家介绍从基于特定月份的MySQL表中选择数据?,包括了从基于特定月份的MySQL表中选择数据?的使用技巧和注意事项,需要的朋友参考一下 使用MySQL中的方法选择基于月份的日期。让我们首先创建一个表- 使用插入命令在表中插入一些记录- 使用select语句显示表中的所有记录- 输出结果 这将产生以下输出- 以下是根据特定月份从表中选择数据的查询- 输出结果 这将产生以下输出-

  • 我在尝试使用Spring Data JPA从数据库中选择distinct值时遇到了这个错误。 无法将值“[a,b,c]”从类型[java.util.ArrayList]转换为类型[@org.springframework.data.jpa.repository.query java.util.List];嵌套异常是org.springframework.core.convert.converter

  • 当我尝试从本机切换到Webview时,错误出现在代码集contextNames=driver。getContextHandles();for(String contextName:contextNames){ System.out.println(contextName);//打印出一些像原生应用程序、WEBVIEW_com.example.android等}String setContext=c

  • 我有这个问题。我正在尝试连接到数据库并推送文本用户。当我打开文件时,我只会发现很多错误。您可以进一步查看错误和我的代码。仅供参考:我的数据库在MySQLi中 警告:mysqli::\uuuu construct():php\u network\u getaddresses:getaddrinfo失败:第3行的/www/webvol9/rj/fxgnq6r66hz6x2j/my domain/pub

  • 我正在使用Maven创建一个Selenium项目,其中我试图从Excel文件(xlsx)中读取“username”和“password”。 这是密码- 我得到的错误在这一行: Driver.FindElement(By.XPath(“//input[@type='text']”)).SendKeys(Sheet.GetRow(i).GetCell(j).GetStringCellValue());