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程序设计有所帮助。