我在用 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)