程序员SpringBoot极简教程 · Spring Boot

JPA 注解参考

2018-01-24  本文已影响244人  聪明的奇瑞
属性 描述
name 可选,对应数据库中的一个表,若表名与实体类相同可忽略
属性 描述
name 可选,映射表的名称,默认表名和实体名一致
catalog 可选,表示catalog目录,一个目录包含多个schema
schema 可选,表示schema模式,一个schema包含多个表、视图等
uniqueConstraints 可选,为实体映射的表设置唯一的约束。该属性可以是一个@UniqueConstraint Annotation数组
@Entity
@Table(name="person_table", indexes = {
        @Index(name="idx_person", columnList="name")
        })
@NamedQuery(
        name="simpleByTest",
        query="SELECT x FROM SimpleModel x WHERE x.test LIKE :test"
    )
public class Person {

    @Id
    @GeneratedValue
    private Long id;
    private String name;
    //...
}
属性 描述
length 可选,指定长度大小
name 可选,字段名称,默认和属性名一致
nullable 可选,是否允许位 null
unique 可选,是否唯一
insertable 可选,表示该字段是否可以出现在 INSERT 语句中
updateable 可选,表示该字段是否可以更新,这对像 birthday 这些一旦创建不能更改属性很有用
columnDefinition 可选,指定创建列时的 SQL 语句
属性 描述
strategy 可选,表示主键生成策略,基于数据库自身功能
generator 可选,指定主键生成器名字,与 @GenericGenerator 结合使用,并与其 name 属性对应
strategy可选 描述
GenerationType.AUTO 根据底层数据库自动选择(默认)
GenerationType.INDENTITY 根据数据库的 Identity(自增长) 字段生成
GenerationType.SEQUENCE 使用 Sequence(序列) 来决定主键取值
GenerationType.TABLE 使用指定表来决定主键取值,结合 @TableGenerator
属性 描述
name 主键生成器名字
strategy 生成策略有 identity(自增)、sequence(序列)、native(根据底层数据库使用不同的策略)、increment(自然递增,与identity不同的是不依赖于底层数据库,而是每次自增长1)、uuid(32位16进制字符串)、assigned(手工分配主键ID)
属性 描述
cascade 可选,表示级联关系
targetEntity 可选,表示关联的实体类型,默认为当前标注实体类
fetch 可选,抓取策略 LAZY、EAGER
optional 可选,表示关联实体能否存在null值,默认为true
mapperBy 可选,双向关联时使用,该属性指定关联实体中哪一个属性可引用到关联实体时采取抓取
cascade可选 描述
CascadeType.ALL 包含所有
CascadeType.PERSIST 级联新建
CascadeType.REMOVE 级联删除
CascadeType.REFRESH 级联刷新
CascadeType.MERGE 级联更新
属性 描述
name 可选,生成的外键列字段名称,默认为:关联表的名称+"_"+关联表主键字段名
referencedColumnName 可选,默认情况下,关联实体的主键一般用来做外键,若不想使用主键作为外键,则需要设置改属性
属性 描述
cascade 可选,表示级联关系
fetch 可选,抓取策略 LAZY、EAGER
optional 可选,表示关联实体能否存在null值,默认为true
属性 描述
cascade 可选,表示级联关系
targetEntity 可选,表示关联的实体类型,默认为当前标注实体类
fetch 可选,抓取策略 LAZY、EAGER
optional 可选,表示关联实体能否存在null值,默认为true
mapperBy 可选,双向关联时使用,该属性指定关联实体中哪一个属性可引用到关联实体时采取抓取

---- 持续更新 ----

上一篇下一篇

猜你喜欢

热点阅读