因为在SPRINGSIDE中增加和修改都是使用同一个XForm.jsp的,在每一个Form里都有一个<input type=”hidden” method=”method” value=”save” />
所以修改和增加都是用同一个Action中的save的方法,
这样就出现了问题了,如果数据表中主键是手动生成的,就是assign的话,那么就产生问题了,
1.增加和修改都是行的,但是当你增加的时候,如果你的主键是相同,其它不同的,也可以执行增加的动作,只是其他的列被覆盖了.
2.在增加的时候,一般是首先查找有没有这个主键,有的话就不增加.所以就在SAVE方法中作了这个判断,那么变成修改的时候,因为在这个判断已经存在的数据就是因为主键存在就不能修改.
解决方法:在表中增加一个delflag的字段,默认值是F,这个字段主要是用来标识增加和修改的操作, 在form.jsp中增加<html:hidden property=”delflag” />
因为在第一次增加的时候是这个form中的delflag是空值,只有在修改的时候这个值会变成
F,所以在save方法中判断if(<T>.getDelflag()= =null)的时候,检索添加的主键在数据表中是否
存在.
其实就是两层判断,1delflag,2主键ID
if(
sysUser.getDelflag()= =null)
//假如得到delflag是空值
try
{
SysUser tUser =
this
.get(sysUser.getId());//
以传入的
id
查找主键是否存在
return
2; //
返回已经存在
}
catch
(Exception e)
{
}
}
try
{
getHibernateTemplate().saveOrUpdate(sysUser);
return
0; //
执行成功
}
catch
(Exception e)
{
e.printStackTrace();
return
1; //
执行失败
}