misterbobo 2015-08-10 07:35 采纳率: 0%
浏览 3055
已结题

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)

  • 写回答

7条回答

  • threenewbee 2015-08-10 07:38
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 关于#python#的问题:自动化测试