关系映射

八:关系映射

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="主键字段名称")

相关推荐