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

相信只要学习了编程的童鞋,都对于增删改查功能被不陌生,在这次所写的小项目中,定义了一个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,这样更新操作就可以顺利进行。

转载于:https://www.cnblogs.com/AsherBlog/p/5434620.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值