zoukankan      html  css  js  c++  java
  • 在更新操作中所需要注意的事项

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

  • 相关阅读:
    UVa1225 Digit Counting
    UVa1586 Molar mass
    UVa1585 Score
    Java中的Set
    CentOS6.5 格式化大磁盘
    Ganglia监控Hadoop与HBase集群
    Hadoop HA + HBase环境搭建(二)————HBase环境搭建
    Hadoop HA + HBase环境搭建(一)————zookeeper和hadoop环境搭建
    在树莓派上安装MongoDB
    编译运行hadoop程序
  • 原文地址:https://www.cnblogs.com/AsherBlog/p/5434620.html
Copyright © 2011-2022 走看看