qq_42002361 2019-07-01 17:47 采纳率: 66.7%
浏览 2698
已采纳

一个奇怪的问题,有关Classforname("com.mysql.jdbc.Driver")报空指针异常

我写了个JDBC工具类,然后测试的时候报空指针异常,我用断点测试出是Class.forname()
这里是null,但是我驱动包之类的都加了啊!然后不死心的我又手写了一个测试类,Class.forname()
又可以连接,就是说工具类就不行,测试类就可以。
下面把代码贴上来,希望又前辈能够指正我的错误。
``
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class JDBCUtils {
private JDBCUtils(){}
private static Connection con = null;
static{
try{
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/mybase";
String username = "root";
String password = "123";
Connection con = DriverManager.getConnection(url,username,password);

 }catch (ClassNotFoundException se){
     se.printStackTrace();
     System.out.println("数据库连接失败");
 } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}   
}
public static Connection getConnection(){
    return con;
}

}

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

public class JDBCTest {
public static void main(String[] args) throws SQLException {

 Connection con = JDBCUtils.getConnection();
 PreparedStatement pst = con.prepareStatement("SELECT sname FROM sort");
 ResultSet rs = pst.executeQuery();
 while(rs.next()){
     System.out.println(rs.getString("sname"));
 }
}

}

上面是我工具类的测试类,下面我把报错信息贴一下

Exception in thread "main" java.lang.NullPointerException
at com.itheima.jdbcutil.JDBCTest.main(JDBCTest.java:13)

下面是我可以正常运行的测试类

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

public class JDBCTest2 {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection( "jdbc:mysql://localhost:3306/mybase","root","123");
PreparedStatement pst = con.prepareStatement("select sname from sort");
ResultSet rs = pst.executeQuery();
while(rs.next()){
System.out.println(rs.getString("sname"));
}
}
}

  • 写回答

2条回答 默认 最新

  • asdf3301 2019-07-01 17:59
    关注

    Connection con = DriverManager.getConnection(url,username,password); //这是新建了一个conn,而不是赋值静态conn

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?