jjzzggkk 2016-06-03 03:27 采纳率: 0%
浏览 2211
已结题

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

我是根据教程利用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;
    }
}

}
图片说明

  • 写回答

16条回答 默认 最新

  • threenewbee 2016-06-03 03:38
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算