这篇文章主要为大家介绍了Spring Data JPA注解Entity使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
1、JPA协议中关于Entity的相关规定
(1)实体是直接进行数据库持久化操作的领域对象(即一个简单的POJO),必须通过@Entity注解进行标示。
(2)实体必须有一个 public 或者 projected的无参数构造方法.
(3)持久化映射的注解可以标示在Entity的字段field上(比较适合使用Lombok的情况),如下所示
除此之外,也可以将持久化注解运用在Entity里面的get/set方法上,通过我们放在get方法中,如下所示:
需要注意的是: 在实体类get方法中加注解时,必须保证set方法的存在,否则会报错
需要注意的是:
在同一个Entity里面只能有一种方式生效,也就是说注解要么全部写在field上面,要么就全部写在get/set方法上
- 只要是在@Entity的实体里面被注解标注的字段,都会被映射到数据库中,除了使用@Transient注解的字段之外。
- 实体里面必须有一个主键。主键表示的字段可以是单个字段,也可以是复合主键字段。
2、常用注解
2.1 JPA支持的注解
2.2 常用注解
@Entity必填项。用于定义对象将会成为被JPA管理的实体,将字段映射到指定的数据库表中,使用起来很简单,直接用在实体类上面即可。
@Table非必填项。 用于指定数据库的表名,表示此实体对应的数据库里面的表名。 默认表名和entity名字一样
@Access非必填项。 用于指定entity里面的注解是写在字段上面,还是get/set方法上面生效。如果默认不填写的情况下,当实体里面的第一个注解出现在字段上或者 get/set方法上面,就以第一次出现的方式为准。
@Id定义属性为数据库的主键,一个实体里面必须有一个主键,但不一定是这个注解。可以和@GeneratedValue配合使用或成对出现。
@GeneratedValue主键生成策略,如下所示:
@Enumerated对Enum枚举类映射到数据库提供下标和name两种方式,用法就是直接映射在enum枚举类型的字段上。
@Basic表示属性是到数据表字段的映射。如果实体的字段上没有任何注解,默认即为@Basic。也就是说默认所有的字段肯定是和数据库进行映射的,并且默认为Eager类型。
@Transient表示非持久化属性。 JPA映射数据库的时候忽略它,与@Basic有相反的作用。
@Column 定义该属性对应数据库中的
3、联合主键
3.1 @IdClass
第一步:新建一个UserInfo类里面的属性是联合主键
第二步 :再新建一个UserInfo的实体,采用@IdClass引用联合主键类
第三步:新增一个UserInfoRepo类来做持久化操作
第四步:测试用例
通过上面例子我们可以发现,我们的表的主键是primary key(name,telephone),而Entity里面不再是一个@Id字段。
执行的SQL如下:
3.2 @Embeddable与@EmbeddedId注解使用
第一步:在上面例子中的UserInfoID里面添加@Embeddable注解
第二步:在UserInfo类中,删除@IdClass,添加@EmbeddeId注解,如下:
第三步:UserInfoRepo保持不变 第四步:测试用例
执行的SQL如下所示:
3.3 两者的区别是什么?
- @Embedded用的是对象,@IdClass用的具体的某一个字段
以上就是Spring Data JPA注解Entity使用示例详解的详细内容,更多关于Spring Data JPA注解Entity的资料请关注编程学习网其它相关文章!