tags: SpringData JPA, title: JPA相关注解解释
@OneToOne的注解#
@Target({METHOD, FIELD})
@Retention(RUNTIME)
public@interfaceOneToOne {
Class targetEntity() default void.class;
CascadeType[]cascade()default();
FetchType fetch() default EAGER;
boolean optional() default true;
String mappedBy() default "";
}
复制代码
1,targetEntity 属性表示默认关联的实体类型,默认为当前标注的实体类。 2,cascade属性表示与此实体一对一关联的实体的级联样式类型。 3,fetch属性是该实体的加载方式,默认为即时加载EAGER 4,optional属性表示关联的该实体是否能够存在null值,默认为ture,如果设置为false,则该实体不能为null, 5, mapperBy属性:mappedBy = "card"中的User类中的getCard()中的Care(去除get) , 如果User类getCard()改为getIdCard(),这里就要写成:mappedBy = "idCard""
#@JoinColumn注解 #
@Target({METHOD, FIELD})
@Retention(RUNTIME)
public@interfaceJoinColumn {
String name() default "";
String referencedColumnName() default "";
boolean unique() default false;
boolean nullable() default true;
boolean insertable() default true;
booleanupdatabledefaulttrue;
String columnDefinition() default "";
String table() default "";
}
复制代码
1,@JoinColumn注释是保存表与表之间关系的字段 2,**如果不设置name,默认name = 关联表的名称+”-“+关联表主键的字段名,在上面实例3,中,默认为“address_id” ** 默认情况下,关联实体的主键一般是用来做外键的,但如果此时不想用主键作为外键,则需要设置referencedColumnName属性,如:
create table address (
id int(20) not null auto_increament,
ref_id int(20) notn ull,
province varchar(50),
city varchar(50),
postcode varchar(50),
detail varchar(50),
primary key(id)
)
@OneToOne@JoinColumn(name="address_id", referencedColumnName="ref_id")
private AddressEO address;
复制代码
如果您觉得这篇文章帮助到了您,可以给作者一点鼓励