java 修改数据库时数据无法更新

代码://修改if("update".equals(type)){//客户端传来的Stringid=request.getParameter("id");Stringus... 代码:
// 修改
if ("update".equals(type)) {
// 客户端传来的
String id = request.getParameter("id");
String username = request.getParameter("username");
String password = request.getParameter("password");
String truename = request.getParameter("truename");
String birthday = request.getParameter("birthday");
String sex = request.getParameter("sex");
String[] interest = request.getParameterValues("interest");
String remark = request.getParameter("remark");

// 将字符串转换成真正的日期类型
java.sql.Date birthdayToDate = null;
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
try {
// 将一个字符串转换成Date
java.util.Date date = sdf.parse(birthday);

birthdayToDate = new java.sql.Date(date.getTime());
} catch (ParseException e) {
// TODO: handle exception
e.printStackTrace();
}

String interestToString = null;
StringBuffer sb = new StringBuffer();
for (int i = 0; i < interest.length; i++) {
sb.append(interest[i]);
}
interestToString = sb.toString();

Users bean = new Users();
//bean.setId(id);
// bean.setUsername(username);
bean.setPassword(password);
bean.setTruename(truename);
bean.setBirthday(birthdayToDate);
bean.setSex(sex);
bean.setInterest(interestToString);
// bean.setRegisterdate(new java.sql.Date(new java.util.Date().getTime()));
bean.setRemark(remark);

UsersDB userDB = new UsersDB();
userDB.update(bean);
//显示所有用户信息
ArrayList arrayList = userDB.getAllUsers();
request.setAttribute("all", arrayList);
request.getRequestDispatcher("/listAllUsers.jsp").forward(request,
response);
//此处查询是java中有值,但查询的时候数据不会改变
System.out.println(id);
System.out.println(username);
System.out.println(password);
System.out.println(truename);
System.out.println(birthdayToDate);
}
// 更新一笔记录
public void update(Users bean) {

try {
//获取连接
Connection con = this.getConnection();
String sql = "update users set password=?,truename=?,birthday=?,sex=?,interest=?,remark=? where id=?";
PreparedStatement ps = con.prepareStatement(sql);

ps.setString(1, bean.getPassword());
ps.setString(2, bean.getTruename());
ps.setDate(3, bean.getBirthday());
ps.setString(4, bean.getSex());
ps.setString(5, bean.getInterest());
ps.setString(6, bean.getRemark());
ps.setInt(7, bean.getId());

ps.executeUpdate();// 真正的完成数据的更新
con.close();

} catch (Exception ex) {
// TODO: handle exception
System.out.println("修改记录发生异常:" + ex.getMessage());
}

System.out.println(bean.getPassword());
System.out.println(bean.getTruename());
System.out.println(bean.getBirthday());

}
展开
 我来答
匿名用户
2012-02-13
展开全部
如楼上所讲:
执行ps.executeUpdate();之后并不会自动进行事务的提交。
需要在之后添加执行
con.commit();
你执行下试一下吧
更多追问追答
追问
修改记录发生异常:Can't call commit when autocommit=true
www
www
1990-06-01
22
qqq
www
www
1990-06-01
追答
autocommit=true 那就不清楚了 应该是会是自动提交的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
aa104045
2012-02-13 · TA获得超过117个赞
知道答主
回答量:246
采纳率:0%
帮助的人:238万
展开全部
UsersDB userDB = new UsersDB();
userDB.update(bean);
UsersDB类里的操作,事务没有提交
更多追问追答
追问
UsersDB类 我补充在上面了帮忙看下 谢谢
ps.executeUpdate();// 真正的完成数据的更新 不是提交么?
追答
ps.executeUpdate();下面加con.commit();测试下

con.close()放在finally{ 里面}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友75ac43264
2012-02-13 · TA获得超过111个赞
知道答主
回答量:136
采纳率:0%
帮助的人:77.2万
展开全部
是不是set参数的值是从0开始赋值的?
更多追问追答
追问
是数据插入的时候?是从1啊!
追答
你试一下从0开始,我记得应该是0
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式