欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用JDBC实现数据访问对象层(DAO)代码示例

程序员文章站 2024-02-23 09:30:16
java是面向对象的语言,开发者在操作数据的时候,通常更习惯面对一个特定类型的对象,如一个用户就是一个user类的对象。dao层需要做的,就是为上层提供充分的对象支持,让上...

java是面向对象的语言,开发者在操作数据的时候,通常更习惯面对一个特定类型的对象,如一个用户就是一个user类的对象。dao层需要做的,就是为上层提供充分的对象支持,让上层再也看不到具体的数据,而是一个个活生生的对象。

增加,删除,查询和修改操作是dao需要做的最基本的4项操作查询一般需要提供遍历查询和id查询,对于遍历查询,dao需要提供user泛型的list对象,对于id查询则提供已经装配好数据的user对象,至于增加和修改操作,上层一般会提供一个user对象,dao把user对象中的数据使用insert语句插入到表格中。删除操作则只需提供一个id即可

class user{
 private long id;
 private string name;
 private string gender;
 public user(){
 super();
 }
 public user(long id,string name,string gender){
 super();
 this.id = id;
 this.name = name;
 this.gender = gender;
 }
 //get,set方法
 }
 //dao类
 public class jdbcdao{
 static{
  try{
   class.forname("com.mysql.jdbc.driver");
  }catch(exception e){
  e.printstacktrace();
   }
  }
 private connection getconn(){
  try{
   return drivermanager.getconnection("jdbc:mysql://localhost:3306:xe","root","password");
   }catch(exception e){
   e.printstacktrace();
   }
  }
  return null;
 }
 private void release(resultset rs,statement ps,connection conn){
  if(rs!=null){
   try{
    rs.close();
   }catch(exception e){
    e.printstacktrace();
   }
  }
  if(ps!=null){
   try{
    ps.close();
   }catch(exception e){
    e.printstacktrace();
   }
  }
  if(conn!=null){
   try{
    conn.close();
   }catch(exception e){
    e.printstacktrace();
   }
  }
 }
 //用id获取用户对象
 public user getuserbyid(long id){
  resultset rs = null;
  preparedstatement ps = null;
  connection conn = null;
  string sql = "select * from user where id = ?";
  try{
   conn = this.getconnection();
   ps = conn.preparestatement(sql);
   ps.setlong(1,id);
   rs = ps.executequery();
   if(rs.next()){
    //如果存在,则直接构建并返回用户对象
    user user = new user(rs.getlong("id"),rs.getstring("name"),rs.getstring("gender"));
    return user;
   }
  }catch(exception e){
   e.printstacktrace();
  }finally{
   this.release(rs,ps,conn);
  }
  return null;
 }
 //查询所有用户
 public list<user> getallusers(){
  list<user> list = new arraylist<user>();
  resultset rs = null;
  preparedstatement ps = null;
  connection conn = null;
  string sql = "select * from user ";
  try{
   conn = this.getconnection();
   ps = conn.preparestatement(sql);
   rs = ps.executequery();
   //循环添加用户对象
   while(rs.next()){
    user user = new user(rs.getlong("id"),rs.getstring("name"),rs.getstring("gender"));
    list.add(user);
   }
  }catch(exception e){
   e.printstacktrace();
  }finally{
   this.release(rs,ps,conn);
  }
  return list;
 }
 //修改用户数据
 public user updateuser(user user){
  preparedstatement ps = null;
  connection conn = null;
  string sql = "update user set id =?,name=?,gender=?";
 try{
   conn = this.getconnection();
   conn.setautocommit(false);
   ps = conn.preparestatement(sql);
   ps.setlong(1,user.getid());
   ps.setstring(2,user.getname());
   ps.setstring(3,user.getgender());
   int rst = ps.executeupdate();
   if(rst>0){
    return new user(user.getid(),user.getname(),user.getgender());
   }
   conn.commit();
  }catch(exception e){
   e.printstacktrace();
   try{
    conn.rollback();
   }catch(exception e1){
    e1.printstacktrace();
   }
  }finally{
   this.release(null,ps,conn);
  }
  return null;
   }
  }
  //删除用户数据
 public boolean deleteuser(long id){
  preparedstatement ps = null;
  connection conn = null;
  string sql = "delete from user where id =?;
 try{
   conn = this.getconnection();
   conn.setautocommit(false);
   ps = conn.preparestatement(sql);
   ps.setlong(1,user.getid());
   ps.setstring(2,user.getname());
   ps.setstring(3,user.getgender());
   int rst = ps.executeupdate();
   if(rst>0){
    return user;
   }
   conn.commit();
  }catch(exception e){
   e.printstacktrace();
   try{
    conn.rollback();
   }catch(exception e1){
    e1.printstacktrace();
   }
  }finally{
   this.release(null,ps,conn);
  }
  return null;
   }
  }
  //插入用户数据
  public user insertuser(user user){
  preparedstatement ps = null;
  connection conn = null;
  string sql = "insert into user values(?,?,?)";
 try{
   conn = this.getconnection();
   conn.setautocommit(false);
   ps = conn.preparestatement(sql);
   ps.setlong(1,user.getid());
   ps.setstring(2,user.getname());
   ps.setstring(3,user.getgender());
   int rst = ps.executeupdate();
   if(rst>0){
    return user;
   }
   conn.commit();
  }catch(exception e){
   e.printstacktrace();
   try{
    conn.rollback();
   }catch(exception e1){
    e1.printstacktrace();
   }
  }finally{
   this.release(null,ps,conn);
  }
  return null;
   }
  }
 }
 }

总结

以上就是本文关于使用jdbc实现数据访问对象层(dao)代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅:jdbc常用接口总结basejdbc和cruddao的写法实例代码jdbc中resutset接口操作实例详解等,如有不足之处,欢迎留言指出,小编会及时回复大家并改正。感谢朋友们对的支持!