一对多关联关系
表
	一方
	多方(外键)
实体类
	一方:TeacherModel
		添加多方的集合Set
	多方StudentModel
		添加一方的对象
一方配置关系
	name:一方模型中描述多方的集合对象名
	column:多方数据库表中的外键名称
	class:多方模型类名
	<set name="students">			
		<key column="teacherUuid"></key>
  	<one-to-many class="cn.itcast.h3.one2many.vo.StudentModel"/>
  </set>
多方配置关系
	name:多方模型中描述一方的对象名
	class:一方模型类名
	column:多方数据库表中的外键名称
	<many-to-one 
		name="teacher"
		class="cn.itcast.h3.one2many.vo.TeacherModel"
		column="teacherUuid"
		/>
关系维护
	添加数据
		1.一方数据与多方数据同时添加
			必须建立一方与多方之间的关联关系
			依靠对象建立对象间的关系
			//多方对一方的关联
			sm1.setTeacher(tm);
			sm2.setTeacher(tm);
			//一方对多方的关联
			tm.getStudents().add(sm1);
			tm.getStudents().add(sm2);
		2.单独添加
			单独添加时不需要进行关系设定
			可以进行添加,注意字段为null的设定
	添加数据时的问题
		1.在添加数据时候,PO对象不能关联TO对象,此时要抛出PO不能关联TO的异常
			解决方案:级联添加
			步骤:为添加方配置级联添加关系
			cascade = save-update
			说明:无论是一对还是多对均可以配置级联添加,但是只规定从当前方可以发起级联操作
			
	删除数据
		1.保留一方数据,删除多方数据
			基本操作
		2.删除一方数据,同时删除对应的多方数据(级联删除)
			步骤:为一方数据添加级联删除特性
			cascade = delete
		3.如果多方断开了与一方的关联,此时多方数据不需要保留,对其进行删除(孤子删除)
			步骤:断开一与多的关系
			cascade = delete-orphan
重要:cascade属性不仅维护级联对象,而且还维护级联关系
	关系维护 inverse
		在一对多的关联关系中,通常使用多方数据来进行关系维护,而一方不需要具有关系维护的能力
		为不具有关系维护能力的一方设置inverse = "true" 可以让当前设置方丧失关系维护权
重要:inverse属性维护关联关系
------------------------------------------------
多对多关系
表
左方:正常(无外键)
右方:正常(无外键)
关系表:双方外键
模型
全部都要加对方的集合Set
hbm.xml配置
双方配置完全相同
		<set 
			name="students" 	当前模型的集合对象名
			table="tbl_relation"	关系表名
			>
        	<key column="teacherUuid"/>	当前模型在关系表中的外键
        	<many-to-many		配置关系
        		class="cn.itcast.h3.many2many.vo.StudentModel"	关联关系对方对象的模型类名
        		column="studentUuid"		关联关系对方对象在关系表中的外键
        		/>
    </set>
    
操作:
	单独添加
		基本H3操作
	同时添加
		绑定关系后,双方都进行关系维护,此时会添加对关系进行两次维护
		解决方案:规定一方为从方,使其失去关系维护权,inverse = "true"
	添加关联关系
		将主从双方没有关联关系的对象,互相添加关联关系
		tm.getStudents().add(sm);
		sm.getTeachers().add(tm);
	删除关联关系
		同添加关联关系
		sm.getTeachers().remove(tm);
		tm.getStudents().remove(sm);
	变更关联关系
		先断开之前的关系	DELETE
		//先解除关系
			tm1.getStudents().remove(sm);
			sm.getTeachers().remove(tm1);
		然后添加新的关系	INSERT
		//再添加关系
			tm2.getStudents().add(sm);
			sm.getTeachers().add(tm2);
	删除数据
			单独删除
			级联删除(不建议)	
-----------------------
一对一关联关系
外键配置方式
	表
		主方:正常
		从方:添加外键约束
	模型
		添加对应模型对象
	配置关系
		主方:
			<one-to-one 
        	name="wife"		主方关联关系对象名
        	class="cn.itcast.h3.one2one.vo.WifeModel"	从方模型类名
        	property-ref="husband"  从方关联关系对象名
        	/>
		从方:
			<many-to-one 
        	name="husband"	从方关联关系对象名
        	class="cn.itcast.h3.one2one.vo.HusbandModel" 主方模型类名
        	column="husbandUuid"   外键字段名
        	unique="true"		设定唯一性
        	/>
主外键配置方式   
	表
		主方:正常
		从方:不添加外键,主键不能做自增
	模型
		添加对应模型对象    	
  配置关系
		主方:
			<one-to-one 
        	name="wife"
        	class="cn.itcast.h3.one2one.vo.WifeModel"
        	/>
		从方:
			主键约束方式发生改变
			 <id name="uuid">
        	<generator class="foreign">		生成策略改为外部提供
        		<param name="property">husband</param>	设置生成策略由属性提供property
        																						属性提供的属性名为husband
        	</generator>
        </id>
        <one-to-one 
        	name="husband"
        	class="cn.itcast.h3.one2one.vo.HusbandModel"
        	constrained="true"	约束为为主键约束
        	/>     
2种配置完成,操作功能完全一样
操作
	单独添加
		主方:
		从方:从方必须依赖于主方的关联关系才可以添加
	同增
		直接绑定关系就可以进行
	级联删除
		读取主方数据,然后配置级联删除操作cascade = delete         	
  	
-------------------------------------------------------------
总结:
对象的状态
	TO
	PO
	DO
	区别
	转换
一级缓存
	实质
	多个,不是唯一的
	一级缓存的操作
	存在性
关联关系
	一对一
	一对多
	多对多
表的制作:
模型制作:
配置:
cascade:规定了级联操作的种类,【同时维护关系】基于inverse=false
inverse:规定了是否维护关系
关联关系中对象的操作是通过 add remove set 操作
原文:https://www.cnblogs.com/xyhero/p/9348823.html