OneToMany、MnatToOne 関係がある 2 つのテーブルがあります。
AlarmnotifyEmailEntity のインスタンスを alarmnotifyEmailEntityList オブジェクトに追加し、AlarmnotifyEmailConfEntity のインスタンスを更新すると、値が正しくデータベースに保存されます。
しかし、alarmnotifyEmailEntityList の項目の 1 つを削除すると、同じことができませんでした。値が alarmnotifyEmailEntityList から削除されていることは確かですが、この変更がデータベースに反映されていません。
@Entity(name ="alarmnotify_email_conf")
@Table(name = "alarmnotify_email_conf")
public class AlarmnotifyEmailConfEntity implements Serializable {
@OneToMany(mappedBy = "alarmnotifyEmailConfRef",cascade=CascadeType.ALL)
private List<AlarmnotifyEmailEntity> alarmnotifyEmailEntityList;
}//end of Class
@Entity (name ="alarmnotify_email")
@Table(name = "alarmnotify_email")
public class AlarmnotifyEmailEntity implements Serializable {
@JoinColumn(name = "alarmnotify_email_conf_ref", referencedColumnName = "id")
@ManyToOne
private AlarmnotifyEmailConfEntity alarmnotifyEmailConfRef;
}end of Class
次のステートメントを呼び出して更新するだけです。
JPAManager.getJPAManagerInstance().update(alarmnotifyemailconf);
public Object update(Object o) {
try {
tx.begin();
EntityManager em = getEntityManager();
System.out.println("updating object:" + o);
o = em.merge(o);
em.close();
tx.commit();
System.out.println("closed and commited merge operation");
return o;
}
catch (Exception e) {
e.printStackTrace();
}
return o;
}