有个jdbc连接数据库的问题望大家帮一下忙 5C

我是根据教程利用odbc做驱动通过jdbc连接sqlserver2008数据库的,数据表已经建立好,odbc加载驱动是成功的,数据库也连接上了,编写的java代码也没有报错,但是就是不能正常运行添加数据,提示是空异常,纠结了好久没能解决,所以在此拜托各位帮个忙解决一下。在此,表示感谢。以下是代码:
用户类
package odbc;

public class User {
private int id;
private String userName;
private String passWord;
private int roleId;

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getUserName() {
    return userName;
}

public void setUserName(String userName) {
    this.userName = userName;
}

public String getPassWord() {
    return passWord;
}

public void setPassWord(String passWord) {
    this.passWord = passWord;
}

public int getRoleId() {
    return roleId;
}

public void setRoleId(int roleId) {
    this.roleId = roleId;
}

public User(){

}

public User(int id, String userName, String passWord, int roleId) {
    super();
    this.id = id;
    this.userName = userName;
    this.passWord = passWord;
    this.roleId = roleId;
}

@Override
public String toString() {
    return "User [id=" + id + ", userName=" + userName + ", passWord="
            + passWord + ", roleId=" + roleId + "]";
}

}
main主函数
package odbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class demo01 {
private Connection conn;
private Statement stat;
public static void main(String[] args) {
new demo01().startup();

}
private  void startup(){
    init();
    //添加一个用户
    User user = new User(1, "zhang", "111", 1);
    addUser(user);

}
private void addUser(User user) {
    String sql = String.format("insert into T_User values('%s','%s',%s)",
            user.getUserName(), user.getPassWord(), user.getRoleId());
    try {
        stat = conn.createStatement();
        int result = stat.executeUpdate(sql);

        if (result > 0) {
            System.out.println("添加用户成功!");
        } else {
            System.out.println("添加用户失败!");
        }

    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } finally {
        try {
            stat.close();
            conn.close();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
private void init(){
    try {
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        System.out.println("加载驱动成功");
        //该语句冒号前面是固定的,冒号后面是自己定义的数据源
        String url = "jdbc:odbc:bookshopsource";        
        Connection conn = DriverManager.getConnection(url);
       System.out.println("数据库连接成功");
    } catch (ClassNotFoundException e) {
        System.out.println("加载驱动失败");
        return;
    }catch (SQLException e) {
        System.out.println("数据库连接失败");
        return;
    }
}

}
图片说明

15个回答

Connection conn = DriverManager.getConnection(url); 我觉得问题应该出现在这里。你在init方法作用域里面赋值conn,出去后conn出现了空指针,你如果是要赋值给全局变量private Connection conn就直接这么写就完了conn = DriverManager.getConnection(url);

zsl79812
呵呵林 正解
3 年多之前 回复
donggua3694857
GrayHJX 回复chen_yongkai: 采纳吧
3 年多之前 回复
donggua3694857
GrayHJX 回复chen_yongkai: 习惯就好~~嘻嘻
3 年多之前 回复
u011606457
_1_1_7_ 蛋疼低级的错误
3 年多之前 回复

String sql = String.format("insert into T_User values('%s','%s',%s)",
user.getUserName(), user.getPassWord(), user.getRoleId());
user的这几个字段都初始化了么

出错的代码是在哪一行

你getConnection(URL,username,password)???不是这样吗?

楼主为什么不用连接池呢?

代码不完整,无法准确判断。出错应该在
stat = conn.createStatement();
int result = stat.executeUpdate(sql);
这2行。
看一下conn和stat哪个是null的。
conn是null的,就是getConnect有问题。
stat是null的,就是sql和数据库定义不一致。

@GrayHJX 说的应该是对的 Connection conn = DriverManager.getConnection(url); 这一行改成 conn = DriverManager.getConnection(url); 你试试

为什么要用%$这中方式,直接用?不是可以,还可以防止SQL注入

demo01.java的第40行报错,你把40行给贴出了,就知道为什么了

去掉init()函数里面定义的connection,直接使用该类的私有成员变量conn。因为你在init()方法里面使用 Connection conn = DriverManager.getConnection(url),重新定义了一个conn变量。这个导致你的类里面的conn对象没有初始化。所以在后面用的时候产生空指针异常。修改方法就是去掉我前面写的那行代码里面的Connection就OK。

共15条数据 1 尾页
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!