简体   繁体   English

使用Hibernate中的无状态会话从对象集合中删除条目

[英]Delete entries from collection of objects using stateless session in hibernate

Is it possible? 可能吗? I try to do it this way, but it doesn't work: 我尝试通过这种方式进行操作,但不起作用:

StatelessSession sess = getSessionFactory().openStatelessSession();
sess.beginTransaction();
MessageDetails md = (MessageDetails) sess.get(MessageDetails.class,1189469L);
md.setCc(null);
sess.update(md);
sess.getTransaction().commit();
sess.close();

cc is defined this way: cc是这样定义的:

@ManyToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@JoinTable(name = "MessageEntryCc")
public Set<EmailAndName> getCc() {
    return cc;
}

After running code, MessageEntryCc still contains entries with message_details_id = 1189469... 运行代码后,MessageEntryCc仍然包含message_details_id = 1189469 ...

Please add CascadeType=DELETE_ORPHAN as well in your mapping as: 请将CascadeType=DELETE_ORPHAN以及您的映射添加为:

  @ManyToMany(fetch = FetchType.LAZY, 
                      cascade={CascadeType.ALL, CascadeType.DELETE_ORPHAN})

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM