在更新操作中所需要注意的事项

相信只要学习了编程的童鞋,都对于增删改查功能被不陌生,在这次所写的小项目中,定义了一个department,里面的did设置为自增形式,当然在查询列表的时候这个did是不被展示出来的,所以需要更新查询列表中的每一行数据更新操作以后,我们在Action中所做的处理是,进行回显操作,而这一部分就需要将这这个所需要更新操作的department放入栈顶:

	//获取数据并保存到栈顶,能够及时回显
	public String updateUI()
	{   System.out.println("haha");
		Department department=departmentService.getDepartmentbyId(this.model.getDid());
		ActionContext.getContext().getValueStack().getRoot().add(0, department);
		return "updatedepartment";
	}

 当然在update.jsp中和添加功能的jsp页面代码大部分相似,如果完全只是复制add.jsp的页面代码并仅仅只是更改一下提交路径的话,就会报错:HTTP Status 500 - Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1; nested exception is org.hibernate.StaleStateException: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1,或者说报错:id to load is required for loading,意思就是说获取的id不对,我在action中updateDepartment方法里面输出department.getDid()得出结果为0,而在这之前查询所得的model中是可以获取出正确的did的,所以为了避免此问题的发生,就需要在update.jsp中添加一个显示框用于显示did,只是将这个显示框的属性设置为不可写入就可,或者是设置隐藏,我的设置如下(did不能进行更改):

<tr><td>部门id</td>
                        <td><s:textfield name="did" class="InputStyle"  readonly="true"/> *</td>
                    </tr>

 这样的话后面就可以正常从这个update.jsp中正常获取did,这样更新操作就可以顺利进行。

posted @ 2016-04-26 12:35  Asher鑫与  阅读(258)  评论(0编辑  收藏  举报