表关联
@Entity
@Table(name = "t_user")
public class User{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
//注意mappenBy的参数为many中的关联属性名称,而非当前的表名称,如果不指定mappenBy,则会生成一张中间表。
@OneToMany(mappedBy = "user")
private Set<Addr> addrs;
}
@Entity
@Table(name = "t_addr")
public class Addr{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String city;
@ManyToOne(fetch = FetchType.EAGER)
//如果不指定JoinColumn,默认生成的关联字段名为`属性名_id`,如这里属性名为user,默认的关联字段名称就是`user_id`
@JoinColumn(name = "user_id")
private User user;
}
@ManyToOne(多对一)单向:不产生中间表,但可以用@JoinColumn(name=" ")来指定生成关联字段的名字,外键在多的一方表中产生,如果不指定@JoinColumn(name=" "),默认生成
字段名_id
的关联字段名称,如果字段名有驼峰,如private DocFile docFile;
,自动生成的关联字段名称则为doc_file_id
。@OneToMany(一对多)单向:会产生中间表,此时可以用@OneToMany和@Joincolumn(name=" ")避免产生中间表,并且指定了外键的名字(别看@joinColumn在一中写着,但它存在在多的那个表中)
@OneToMany,@ManyToOne 双向(两个注解一起用的):如果不在@OneToMany中加mappedBy属性就会产生中间表,此时通常在@ManyToOne的注解下再添上注解@JoinColumn(name=" ")来指定外键的名字(说明:多的一方为关系维护端,关系维护端负责外键记录的更新,关系被维护端没有权利更新外键记录)!(@OneToMany(mappedBy="一对多中,多中一的属性")出现mappedBy为被维护端|||默认为延迟加载)