JDBC-ODBC桥连接时出现空指针异常 5C

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

7个回答

ct = DriverManager.getConnection("jdbc:odbc:mytest");
看下这个mytest是否存在

misterbobo
misterbobo mytest在ODBC中已经建好了,而且测试数据源也是成功的。
大约 5 年之前 回复

连接时候 出问题了 你看一下 链接

用户名跟密码都没有输入,还有查看下你要访问的数据库名称是不是mytest这个名字

misterbobo
misterbobo 我建立mytest数据源的时候采用的是windowsNT验证,不需要用户名和密码的。
大约 5 年之前 回复

mytest 是不是数据源的名称而不是数据库的名称,如果这里没有就看看有没有jar包了

ascdfwsfrfadfg
inc1ud3 回复misterbobo: http://blog.csdn.net/lissdy/article/details/7059828
大约 5 年之前 回复
misterbobo
misterbobo mytese检查过,是数据源(ODBC)的名称。而且jar包导入了,导入的包是rt.jar,要不然会报类错误。
大约 5 年之前 回复

at JDBC_ODBC.main(JDBC_ODBC.java:28)

数据库链接异常,看看数据库用户名,密码,数据库名字对么

先定位到你具体异常的语句。然后看哪个变量是空指针等。

ODBC连接异常,说明你在ODBC上配置的数据库链接不对,你检查一下

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐