关系映射
?
八:关系映射
1) 一对一关联
规律:凡是双向关联,必设mappedBy="true"
a)一对一(单向外键) 关联
annotation:@OneToOne @JoinColumn(name="")
xml:<many-to-one name="关联的模型类名称" column="制定关联主键的列名称"?
?
unique="true"></many-to-one> 说明是一对一关联(因为加了unique="true")
b)一对一(双向外键) 关联
在(Husband)主类中已经设置了@OneToOne的设置了,双向关联,则在双向关联的类(Wife)中也需要
?
设置@OneToOne
但是一对一双向外键关联需要增加(mappedBy="wife"),说明了一对一双向外键关联必须设置
?
mappedBy="wife".
annotation:@OneToOne(mappedBy)
?
c)一对一单向主键关联
? ?annotation:@PrimaryKeyJoinColumn(name="")
?
d)一对一双向主键关联
?
e)联合主键关联
?
?反向工程
?
?
组件映射
annotation:@Embeded?
xml:<composit>
主键映射的时候继承序列化接口
?
一对多,多对一关联
?
多对一单向关联
数据库表设计:在多方加外键
?
annotation:@ManyToOne
xml<many-to-one>
怎么规划你的将来?
?
数据库表的设计:在设计数据库表的时候一定切记不能存在冗余(特定问题特定分析)
a)遵守三范式: ?
? 1:要有主键列不可以再分,
? 2:联合主键的依赖不能存在部分依赖
? 3:不能存在传递依赖
?
一个人可以有多个理想,一个具体的梦想只可以属于一个人。
?
?
?
一对多单向关联
类:在一的一方存在多方的集合。
数据库表同上。
?
对象模型:在设计类的时候,使用hibernate则需要使用对象生成的机制。
数据库模型:在设计数据库的时候考虑不要出现冗余表
?annotation:@OneToMany
? ? ?@JoinColumn(name="group_Id")
? xml:<set>,<one-to-many>
?
一对多和多对一双向关联
使用双向必须使用mappedBy,如果不指定则出现两个相同外键字段
数据库设计在多的一方外键,在类中设计在一方:mappedBy="属性名称"
?
?
多对多单向关联
例如:老师和学生的关系,老师需要知道自己教了那些学生
数据库模型设计:在设计数据库表的时候加一张中间表。
对象模型设计:
annotation:@ManyToMany
? ? ? ? ? ?@JoinTable(name="t_s",
joinColumns={@JoinColumn(name="teacher_id")},
inverseJoinColumns={@JoinColumn(name="student_id")}
)
?
多对多双向关联
例如:老师和学生的关系,老石需要知道自己有那些学生。学生知道那些老师
?
?
?
?
关联关系的CRUD(重点)
创建:create
多对一:
在多方操作的设置:的一方设立annotation为@Cascade(CascadeType.ALL)为保存表之间的关联关联
?
键值。
cascade为关联为表插入值有关联数据对应值。
一对多:
在一方的操作的设置。
?
设定CASCADE可以设定在持久化编程时候对于关联对象的操作
cascade仅仅是帮我们省了编程的麻烦作用不大
? a)cascade的属性指明做什么操作的时候关联对象是绑在一起。
? b)merge=save_update
? c)refersh=A里面需要读取B改过之后的数据
规律:双向关系在程序中要设定双向关联
规律:双向mayppedBy
?
cascade管增删改,fetch管理读
?
?
更新:update
cascade=CascadeType.ALL
?
删除:delete
删除和更新的同时先查询下。
设置Cascade=CascadeType.REMOVE
如果要消除关联关系先设定关联关系为NULL,在删除对应记录,如果不删除记录,该记录就变成垃圾
?
数据。
?
O/R Mapping 编程模型
?1)映射模型
? ?JPA annotation(核心)
? ?hibernate annotation extension
? ?hibernate xml
? ?jpa xml
?
? 2)编程接口
? ? JPA (核心)
? ? hibernate
? 3)数据查询语言
? ? HQL
? ? EJBQL(JPQL)
?
作业:树状结构的设计(至关重要)
? 在同一个类中使用OneToMany和ManyToOne
?
?
关联关系总结:
?1)什么关系类型,设定什么关系表,使用什么关系映射。
?2)CRUD,动手实战。
?
集合映射
? 1)Set
? 2)List
? ? ?list 存储多的一方,应该怎么存储数据。
? ? ?list可以排序,可以使用@orderBy排序
? 3)Map
? ? @MapKey(name="主键字段名称")
?