JDBC程序更新数据库中记录的方法
本文实例讲述了JDBC程序更新数据库中记录的方法。分享给大家供大家参考,具体如下:
使用JDBC程序(Eclipse、MyEclipse)更新数据库(MySql)中的记录时可以只修改记录的一个字段或几个字段,具体方法为可以加入如下被注释代码(前提是修改之前可以从数据库中得到该条记录)以user表为例
publicclassUserDaoJdbcImplimplementsUserDao{ publicvoidupdate(Useru){ Connectionconn=null; PreparedStatementps=null; ResultSetrs=null; try{ conn=JdbcUtils.getConnection(); Stringsql="updateusersetname=?,birthday=?,money=?whereid=?"; ps=conn.prepareStatement(sql); //首先得到该记录 Useruser=getUserById(u.getId()); //判断字段是否需要修改 if(u.getName()==null){ u.setName(user.getName()); } if(u.getBirthday()==null){ u.setBirthday(user.getBirthday()); } if(u.getMoney()==0){ u.setMoney(user.getMoney()); } ps.setString(1,u.getName()); ps.setDate(2,newjava.sql.Date(u.getBirthday().getTime())); ps.setDouble(3,u.getMoney()); ps.setInt(4,u.getId()); inti=ps.executeUpdate(); System.out.println("成功向user表中更新"+i+"条记录"); }catch(SQLExceptione){ e.printStackTrace(); }finally{ JdbcUtils.free(rs,ps,conn); } } publicUsergetUserById(intid){ Connectionconn=null; PreparedStatementps=null; ResultSetrs=null; Useruser=null; try{ conn=JdbcUtils.getConnection(); Stringsql="select*fromuserwhereid=?"; ps=conn.prepareStatement(sql); ps.setInt(1,id); rs=ps.executeQuery(); if(rs.next()){ user=newUser(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setBirthday(rs.getDate("birthday")); user.setMoney(rs.getDouble("money")); } }catch(SQLExceptione){ e.printStackTrace(); }finally{ JdbcUtils.free(rs,ps,conn); } returnuser; } }
调用:
publicstaticvoidmain(String[]args){ UserDaoud=newUserDaoJdbcImpl(); Useruser=newUser(); user.setId(9); user.setName("老师");//只修改name和birthday属性 Dated=null; try{ SimpleDateFormatsdf=newSimpleDateFormat("yyyy-MM-dd"); d=sdf.parse("1999-9-14"); }catch(ParseExceptione){ e.printStackTrace(); } user.setBirthday(d); //user.setMoney(1234);不修改money属性 ud.update(user); }
希望本文所述对大家Java程序设计有所帮助。