persist用来新增记录、merge用来更新记录;merge同时也可以用来新增记录,但persit不能用来更新记录。但用merge的时候需要注意以下问题:
- 用merge来新增主体对象:
- 最好用merge的返回值赋值给原有的对象,不然像自动生产字段(如id)、post事件对对象的修改将体现不到原有的对象,似乎重新生成了新对象。
- 使用postPersist等事件来处理逻辑时,会发现获取不到关联的子对象和transient字段,也即去不到非持久化的对象。
- 用merge更新主对象,但如果相关联的子对象(oneToOne、oneToMany)的cascase使用了merge策略的话,且子对象为新对象或含有新对象,所以也存在上述的b问题。cascase只是让你少写代码而已,所以最好先将新增子对象persist好了之后再对主体进行merge。
总结:如果有使用Jpa的post事件(persist、update),最好不管主对象还是子对象新增一定用persit、更新一定用merge就不会出错,可以封装一个saveOrUpdate来实现。