我在用 jdbc-odbc 桥连方式操作 sql server 数据库时出现空指针异常
Connection ct = null;
Statement sm = null;
try {
//(1)加载驱动(作用是把需要的驱动程序加入内存)
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
//(2)得到连接(指定连接到哪个数据库)
ct = DriverManager.getConnection("jdbc:odbc:mytest");
System.out.println("数据库成功连接");
//(3)创建Statement或者preparedStatement
sm = ct.createStatement();
//(4)执行CRUD
//添加一条数据到dept表
int i = sm.executeUpdate("insert into dept values('50','security','beijing')");
if(i==1){
System.out.println("添加成功");
}else{
System.out.println("添加失败");
}
} catch (Exception e) {
e.printStackTrace();
}finally{
//以上的语句执行完成之后需要关闭数据源
//关闭的顺序:谁先创建谁后关闭
try{
if(sm != null){
sm.close();
}
if(ct != null){
ct.close();
}
}catch (SQLException e){
e.printStackTrace();
}
}
出现异常描述如下:
java.lang.NullPointerException
at sun.jdbc.odbc.JdbcOdbcDriver.initialize(JdbcOdbcDriver.java:436)
at sun.jdbc.odbc.JdbcOdbcDriver.connect(JdbcOdbcDriver.java:153)
at java.sql.DriverManager.getConnection(DriverManager.java:664)
at java.sql.DriverManager.getConnection(DriverManager.java:270)
at JDBC_ODBC.main(JDBC_ODBC.java:28)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140)
ct = DriverManager.getConnection("jdbc:odbc:mytest");
看下这个mytest是否存在
连接时候 出问题了 你看一下 链接
用户名跟密码都没有输入,还有查看下你要访问的数据库名称是不是mytest这个名字
mytest 是不是数据源的名称而不是数据库的名称,如果这里没有就看看有没有jar包了
at JDBC_ODBC.main(JDBC_ODBC.java:28)
数据库链接异常,看看数据库用户名,密码,数据库名字对么
先定位到你具体异常的语句。然后看哪个变量是空指针等。
ODBC连接异常,说明你在ODBC上配置的数据库链接不对,你检查一下