hibernate之一对多和多对一中的inverse和cascade两个关键字的区别及使用

inverse顾名思义控制反转

<set name="setEmployees" table="employee" inverse="false" cascade="save-update,delete">
      <key column="dept_id"></key>
      <one-to-many class="Employee"/>
</set>

在集合中inverse默认是false,意思就是拥有对Employee的控制权,对第二张表的增删改查都有权限

而把它的值改成了true后,就失去了改变第二张表的权限,也就是说,你查询第二张表可以,但是你要是想改变第二张表的数据,对不起不行

而cascade属性顾名思义是级联的意思

他的默认值为none,也就是说不会帮你级联到任何一张表,按道理我们用到这个属性会很少,因为他是一个危险的属性,就像你一般用delete不用drop来对一张表进行操作

他的作用和inverse有点像,但是也有鲜明的区别

cascade有五个值,"save-update","delete","save-update,delete","none","all"

其中和inverse主要的区别是在于delete,cascade的比较僵硬,他在删除主表中的数据的同时附表的相关的数据也会一并删除,而inverse比较温柔,只是将附表的相关元素改为null,然后再去删除主表中你要删除的行