问题描述
- JDBC-ODBC桥连接时出现空指针异常
-
我在用 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上配置的数据库链接不对,你检查一下