我参考视频做的SSH CRUD的例子 用的Oracle数据库
视频中只有查询和添加的演示,没录制修改的部分,我自己做的时候,查询 添加 删除可以正常工作 但更新时出现如上错误.查询了一些资料,基本上确定是由于Hibernate主键生成方法是"assigned"但是在Dao层saveOrUpdate()方法中没有获得主键id的值造成的 需要再save前添加setID()方
照理说这已经很明确的给出解决方法了,但我实在基础太差,没有实际例子没法掌握,请问这个"加入setID()"究竟是在那一层,用哪种方式加入呢.下面是我的一些代码.表名是 PERSON 对应实体类Person
PersonDaoHibernate
[code="java"]
public void update(Person p) {
getHibernateTemplate().update(p);
}
[/code]
PersonManagerImpl
[code="java"]
public void updatePerson(Person p) {
personDao.update(p);
}
[/code]
PersonAction
[code="java"]
public String update() {
person = personManager.get(id);
personManager.updatePerson(person);
return SUCCESS;
}
[/code]
id最好是自动生成:
如果是配置Hbm文件,可以加入
如果是注解:@GeneratedValue(strategy=GenerationType.IDENTITY)
public Long getId() {
return id;
}
你用的是Oracle数据库,可以在Person的id中这样配置:
[code="java"]
@Id
@GeneratedValue(generator = "uuid")
@GenericGenerator(name = "uuid", strategy = "org.hibernate.id.UUIDGenerator")
@Column(name = "ID", unique = true, nullable = false, length = 50)
public String getId() {
return this.id;
}
[/code]
可以在页面上存下person.id,如果id是空的则新增,如果不是空的,则根据ID得到person,然后修改