<html><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">class Address {<div>&nbsp;&nbsp;@ManyToOne Country country;</div><div>&nbsp;&nbsp;@ManyToOne State state;</div><div>&nbsp;&nbsp;@ManyToMany Set&lt;Person> inhabitants;</div><div>}</div><div><br></div><div>It generally makes no sense to cascade persist for these three associations. Even if your app has 80 entities, it's very likely that half of the associations should not be cascaded :)</div><div><br></div><div>Let's take your proposal</div><div>PERSIST, DELETE, REFRESH</div><div><br></div><div>I REFRESH address and changes on Person are lost, doh!</div><div>PERSIST, do I really save an address and expect the person living there to be added to the system. Surely not, the person is very likely to have been built&nbsp;beforehand. Same for Country and State.</div><div>MERGE Do I really want to update a country when an address changes? I can't find a system that would do that.</div><div><br></div><div>Cascade has performance consequences. The more cascades the slower your app will be at flush time. Especially on applications with a lot of entities.</div><div><br></div><div>NONE is a good default, that's why it's the default we have chosen :)</div><div><br></div><div><br><div><div>On &nbsp;Mar 4, 2009, at 14:38, Dan Allen wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div class="gmail_quote">On Wed, Mar 4, 2009 at 2:17 PM, Emmanuel Bernard <span dir="ltr">&lt;<a href="mailto:emmanuel@hibernate.org">emmanuel@hibernate.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"> <div style="">Then add @*to*(cascade=CascadeType.PERSIST), it will take you 2 mins to do what you really like and you will know you do it.</div></blockquote><div><br>It doesn't take two minutes when you have 80 entities. Most apps have large databases. Rarely do you see simple schemas like we have in the examples. When you generate your entities again and have to start all over. I think this is a good default to have, as well as DELETE and maybe REFRESH. Daniel can speak better to what he is seeing out in the field.<br> <br>NONE is a crappy default.<br><br>-Dan<br></div></div><br>-- <br>Dan Allen<br>Senior Software Engineer, Red Hat | Author of Seam in Action<br><br><a href="http://mojavelinux.com">http://mojavelinux.com</a><br><a href="http://mojavelinux.com/seaminaction">http://mojavelinux.com/seaminaction</a><br> <br>NOTE: While I make a strong effort to keep up with my email on a daily<br>basis, personal or other work matters can sometimes keep me away<br>from my email. If you contact me, but don't hear back for more than a week,<br> it is very likely that I am excessively backlogged or the message was<br>caught in the spam filters. &nbsp;Please don't hesitate to resend a message if<br>you feel that it did not reach my attention.<br></blockquote></div><br></div></body></html>