本博客参照https://blog.csdn.net/petercnmei/article/details/54893622
mappedBy 单向关系不需要设置该属性,双向关系必须设置,避免双方都建立外键字段
mappedBy属性也能避免会多出一张表,这样也能有效减少SQL语句(可设置属性用n的一方来维护关联关系,而1的一方不维护)
数据库中1对多的关系,关联关系总是被多方维护的即外键建在多方,比如我们在单方对象的@OneToMany(mappedby=” “)把关系的维护交给多方 对象的属性去维护关系
既
a) 只有OneToOne,OneToMany,ManyToMany上才有mappedBy属性,ManyToOne不存在该属性;
b) mappedBy标签一定是定义在the owned side(被拥有方 主表),他指向theowning side(拥有方 外键关联的子表);
c) 关系的拥有方负责关系的维护,在拥有方建立外键。所以用到@JoinColumn
d)mappedBy跟JoinColumn/JoinTable总是处于互斥的一方(只能有一个、否则报空指针异常)