浅谈Hibernate关系映射(4)

继上篇博客

 

多对多关联映射(单向)

 

多对多对象关系映射,需要加入一张新表完成基本映射。

  • Hibernate会自动生成中间表
  • Hibernate使用many-to-many标签来表示多对多的关联,多对多的关联映射,在实体类中,跟一对多一样,也是用集合来表示的。

 

如下图所示

                     

通过User可以查看Role的信息

 

User的映射文件

<hibernate-mapping>
	<class name="com.bjpowernode.hibernate.User">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="roles" table="t_user_role">
			<key column="user_id"></key>
			<many-to-many class="com.bjpowernode.hibernate.Role" column="role_id"></many-to-many>
		</set>		
	</class>	
</hibernate-mapping>

Role的映射文件

<hibernate-mapping>
	<class name="com.bjpowernode.hibernate.Role">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>	
	</class>	
</hibernate-mapping>

多对多关联映射(双向)

 

双向多对多对象关系映射,是两端都能将对方加载上来,双向都需要加上标签映射。

要注意:

*生成中间表名必须一样

*生成中间表字段必须一样

                      


User的映射文件:

<hibernate-mapping>
	<class name="com.bjpowernode.hibernate.User">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="roles" table="t_user_role">
			<key column="user_id"></key>
			<many-to-many class="com.bjpowernode.hibernate.Role" column="role_id"></many-to-many>
		</set>		
	</class>	
</hibernate-mapping>

Role的映射文件

<hibernate-mapping>
	<class name="com.bjpowernode.hibernate.Role">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="users" table="t_user_role">
			 <key column="role_id"></key>
			 <many-to-many class="com.bjpowernode.hibernate.User"></many-to-many>
		</set>
	</class>	
</hibernate-mapping>

区别:单向多对多和双向多对多存储结构没有任何的区别,但他们的映射文件是有区别的,加载过程是不同的。

 

 

关系映射总结

 

      综上所述,可以看出,同一类映射,无论是单向还是双向,他们的存储结构是相同的,之所以映射文件不同,是因为加载时不同(在增删改时)即要通过谁能看到谁,还是互相都能看到。

      无论是一对多,多对多,还是一对一等关系,例如:Student---IdCard,学生想知道卡信息,那么Student端就会有IdCard的引用,反过来也就是双向的关系的话,通过IdCard想要知道Student的信息,那么IdCard端就要要Student的引用(实体关系上的体现)!

 



浅谈Hibernate关系映射(4),古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。