1、JPA协议中关于Entity的相关规定

(1)实体是直接进行数据库持久化操作的领域对象(即一个简单的POJO),必须通过@Entity注解进行标示。

(2)实体必须有一个 public 或者 projected的无参数构造方法.

(3)持久化映射的注解可以标示在Entity的字段field上(比较适合使用Lombok的情况),如下所示

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(columnDefinition = "int(11) NOT NULL COMMENT '主键' ")
private Integer id;
@Column(columnDefinition = "varchar(30) DEFAULT '' COMMENT '书名'")
private String bookName;
@Column(columnDefinition = "int(11) DEFAULT 0  COMMENT '数量'")
private Integer amount;

除此之外,也可以将持久化注解运用在Entity里面的get/set方法上,通过我们放在get方法中,如下所示:
需要注意的是: 在实体类get方法中加注解时,必须保证set方法的存在,否则会报错

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(columnDefinition = "int(11) NOT NULL COMMENT '主键' ")
public Integer getId() {
    return id;
}
@Column(columnDefinition = "varchar(30) DEFAULT '' COMMENT '宠物名'")
public String getName() {
    return name;
}
@Column(columnDefinition = "int(11) DEFAULT NULL COMMENT '年龄'")
public Integer getAge() {
    return age;
}

需要注意的是:

在同一个Entity里面只能有一种方式生效,也就是说注解要么全部写在field上面,要么就全部写在get/set方法上

  • 只要是在@Entity的实体里面被注解标注的字段,都会被映射到数据库中,除了使用@Transient注解的字段之外。
  • 实体里面必须有一个主键。主键表示的字段可以是单个字段,也可以是复合主键字段。

2、常用注解

2.1 JPA支持的注解

2.2 常用注解

@Entity必填项。用于定义对象将会成为被JPA管理的实体,将字段映射到指定的数据库表中,使用起来很简单,直接用在实体类上面即可。

 @Target(TYPE) // 表示此注解只能用在class上面
 @Retention(RUNTIME)
 public @interface Entity {
    // 默认是实体类的名字
    String name() default "";
 }

@Table非必填项。 用于指定数据库的表名,表示此实体对应的数据库里面的表名。 默认表名和entity名字一样

  @Target(TYPE)  // 表示此注解只能用在class上面
  @Retention(RUNTIME)
  public @interface Table {
      // 表的名字,默认表名和entity名字一样
      String name() default "";
      // 表的目录
      String catalog() default "";
      // 此表所在schema
      String schema() default "";
      // 唯一性约束,在创建表的时候有用,表创建好之后后面就不需要了
      UniqueConstraint[] uniqueConstraints() default {};
      // 索引,在创建表的时候使用,表创建之后后面就不需要了
      Index[] indexes() default {};
  }
  // 单一字段唯一性约束
  uniqueConstraints = {@UniqueConstraint(name = "unique_age",columnNames = "age")}
  // 联合约束
  uniqueConstraints = {@UniqueConstraint(name = "unique_name",columnNames = {"name","age"})}
  // 索引
  indexes = {@Index(name = "nameIndex",columnList = "name")})

@Access非必填项。 用于指定entity里面的注解是写在字段上面,还是get/set方法上面生效。如果默认不填写的情况下,当实体里面的第一个注解出现在字段上或者 get/set方法上面,就以第一次出现的方式为准。

@Target( { TYPE, METHOD, FIELD }) // 表示此注解可以运用在类上(可以指定实体的默认注解生成策略),也可以用在方法上或字段上(表示可以独立设置某一个字段或者方法的生效策略)
@Retention(RUNTIME)
public @interface Access {
    AccessType value();
}
public enum AccessType {
    FIELD,
    PROPERTY
}
@Access(value = AccessType.FIELD)

@Id定义属性为数据库的主键,一个实体里面必须有一个主键,但不一定是这个注解。可以和@GeneratedValue配合使用或成对出现。

@GeneratedValue主键生成策略,如下所示:

public @interface GeneratedValue {
    // Id的生成策略
    GenerationType strategy() default AUTO;
    // 通过Sequences生成Id,常见的是Oracle数据库ID生成规则,这个时候需要配合@SequenceGenerator使用
    String generator() default "";
}
// 生成策略
public enum GenerationType { 
    // 通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植
    TABLE, 
    // 通过序列产生主键,通过@SequenceGenerator 注解指定序列名,MySql不支持这种方式
    SEQUENCE, 
    // 采用数据库Id自增长,一般用于Mysql数据库
    IDENTITY, 
    // 自动选择合适的策略,是默认选项;
    AUTO
}

@Enumerated对Enum枚举类映射到数据库提供下标和name两种方式,用法就是直接映射在enum枚举类型的字段上。

@Target({METHOD, FIELD}) 
@Retention(RUNTIME)
public @interface Enumerated {
    EnumType value() default ORDINAL;
}
public enum EnumType {
    // 映射枚举字段的下标
    ORDINAL,
    // 映射枚举的Name
    STRING
}

@Basic表示属性是到数据表字段的映射。如果实体的字段上没有任何注解,默认即为@Basic。也就是说默认所有的字段肯定是和数据库进行映射的,并且默认为Eager类型。

public @interface Basic {
    // EAGER 立即记载;LAZY 延迟加载;
    FetchType fetch() default EAGER;
    // 这个字段是否可以为null,默认是true
    boolean optional() default true;
}

@Transient表示非持久化属性。 JPA映射数据库的时候忽略它,与@Basic有相反的作用。

@Column 定义该属性对应数据库中的

public @interface Column {
    // 定义了被标注字段在数据库表中所对应字段的名称;
    String name() default "";
    // 表示该字段是否为唯一标识
    boolean unique() default false;
    // 数据字段是否允许为空,默认为空
    boolean nullable() default true;
    // 表示在使用“INSERT”脚本插入数据时,是否需要插入该字段的值。
    boolean insertable() default true;
    // 表示在使用“UPDATE”脚本插入数据时,是否需要更新该字段的值
    boolean updatable() default true;
    // 表示创建表时,该字段创建的SQL语句,一般用于通过Entity生成表定义时使用
    String columnDefinition() default "";
    // 表示当映射多个表时,指定表的表中的字段。默认值为主表的表名。
    String table() default "";
    // 表示字段的长度,当字段的类型为varchar时,该属性才有效,默认为255个字符。
    int length() default 255;
    // 表示数值的总长度
    int precision() default 0;
    // 表示小数点所占的位数,必须和precision搭配使用
    int scale() default 0;
}

3、联合主键

3.1 @IdClass

第一步:新建一个UserInfo类里面的属性是联合主键

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class UserInfoID implements Serializable {
    private String name;
    private String telephone;
}

第二步 :再新建一个UserInfo的实体,采用@IdClass引用联合主键类

@Entity
@Data
@Builder
@IdClass(UserInfoID.class)
@AllArgsConstructor
@NoArgsConstructor
public class UserInfo {
    private Integer ages;
    @Id
    private String name;
    @Id
    private String telephone;
}

第三步:新增一个UserInfoRepo类来做持久化操作

public interface UserInfoRepo extends JpaRepository<UserInfo, UserInfoID> {
}

第四步:测试用例

@Test
public void queryIndex2(){
    userInfoRepo.save(UserInfo.builder()
    .ages(1)
    .name("jack")
    .telephone("123456789").build());
    userInfoRepo.findById(UserInfoID.builder()
            .name("jack")
            .telephone("123456789").build());
}

通过上面例子我们可以发现,我们的表的主键是primary key(name,telephone),而Entity里面不再是一个@Id字段。

执行的SQL如下:

3.2 @Embeddable与@EmbeddedId注解使用

第一步:在上面例子中的UserInfoID里面添加@Embeddable注解

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@Embeddable
public class UserInfoID implements Serializable {
    private String name;
    private String telephone;
}

第二步:在UserInfo类中,删除@IdClass,添加@EmbeddeId注解,如下:

@Entity
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class UserInfo {
    private Integer ages;
    @EmbeddedId
    private UserInfoID userInfoID;
    @Column(unique = true)
    private String uniqueNumber;
}

第三步:UserInfoRepo保持不变 第四步:测试用例

@Test
public void queryIndex(){
    userInfoRepo.save(UserInfo.builder()
            .ages(1)
            .userInfoID(UserInfoID.builder()
                    .name("jack")
                    .telephone("123456789").build()).build());
    userInfoRepo.findById(UserInfoID.builder()
            .name("jack")
            .telephone("123456789").build());
}

执行的SQL如下所示:

3.3 两者的区别是什么?

  • @Embedded用的是对象,@IdClass用的具体的某一个字段

以上就是Spring Data JPA注解Entity使用示例详解的详细内容,更多关于Spring Data JPA注解Entity的资料请关注Devmax其它相关文章!

Spring Data JPA注解Entity使用示例详解的更多相关文章

  1. Spring Data JPA系列JpaSpecificationExecutor用法详解

    这篇文章主要为大家介绍了Spring Data JPA系列JpaSpecificationExecutor用法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  2. Spring Boot 整合持久层之Spring Data JPA

    在介绍Spring Data JPA的时候,我们首先认识下Hibernate。Hibernate是数据访问解决技术的绝对霸主,使用O/R映射技术实现数据访问,O/R映射即将领域模型类和数据库的表进行映射,通过程序操作对象而实现表数据操作的能力,让数据访问操作无须关注数据库相关的技术

  3. 使用JPA插入枚举类型字段

    这篇文章主要介绍了使用JPA插入枚举类型字段,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  4. 使用JPA单项一对多外键关联

    这篇文章主要介绍了使用JPA单项一对多外键关联,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  5. 使用spring jpa 如何给外键赋值

    这篇文章主要介绍了使用spring jpa 如何给外键赋值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  6. Spring JPA 增加字段执行异常问题及解决

    这篇文章主要介绍了Spring JPA 增加字段执行异常问题及解决,具有很好的参考价值,

  7. Spring Data JPA踩坑记录(@id @GeneratedValue)

    这篇文章主要介绍了Spring Data JPA踩坑记录(@id @GeneratedValue),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  8. Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用

    Spring Data JPA是Spring Data的子项目,在使用Spring Data JPA之前,先了解一下Hibernate,因为Spring Data JPA是由Hibernate默认实现的

  9. 使用JPA双向多对多关联关系@ManyToMany

    这篇文章主要介绍了使用JPA双向多对多关联关系@ManyToMany,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  10. SpringBoot利用jpa连接MySQL数据库的方法

    这篇文章主要介绍了SpringBoot利用jpa连接MySQL数据库的方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部