JPA API与注解

时间:2021-09-26 13:36:14

一、JPA API

  • Persistence 类:用于获取 EntityManagerFactory 实例,该类含有静态方法 createEntityManagerFactory
//persistence.xml 中的 persistence-unit
String persistenceUnitName = "jpa-1";
EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory(persistenceUnitName);

还可以使用 map 来配置 hibernate。

Map map = new HashMap<String, Object>();
map.put("hibernate.show_sql", false);
EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory(persistenceUnitName, map);
  • EntityManagerFactory 接口:创建 EntityManager 实例,该接口有以下几个方法:

    • createEntityManager():用于创建实体管理对象实例。
    • isOpen():检查 EntityManagerFactory 是否处于打开的状态。默认创建后就一直是打开的,除非调用close() 方法将其关闭。
    • close():关闭 EntityManagerFactory, EntityManagerFactory 关闭后将释放所有资源,其他方法将不能调用,否则将导致 IllegalStateException 异常。
  • EntityManager 类:该类是完成持久化操作的核心对象,实体作为普通的 Java 对象,只有在调用 EntityManager 将其持久化后才会变成持久化对象。它有以下几个方法:

    • find(Class entityClass,Object primaryKey):返回指定的 OID 对应的实体类对象。

      //若 OID 不存在于数据库中,则会返回一个 null
      Customer c = entityManager.find(Customer.class, 2);
    • getReference (Class entityClass,Object primaryKey):与 find 方法类似,但是采用懒加载的方式,并且如果数据库中不存在此 OID,会抛出 EntityNotFoundException。

      //若 OID 不存在于数据库中,则会抛出 EntityNotFoundException 异常
      Customer c = entityManager.getReference(Customer.class, 2);
      // 由于懒加载,此行结果会先于 SQL 语句显示出来
      System.out.println("-------");
      System.out.println(c.getLastName());
    • persist(Object entity):用于将新创建的 Entity 从新建状态转为持久化状态即插入数据,也能更新数据。

      Customer customer = new Customer();
      customer.setAge(15);
      customer.setLastName("Tom");
      customer.setEmail("Tom@163.com"); entityManager.persist(customer);
      Customer customer = entityManager.find(Customer.class, 1);
      customer.setLastName("Tom");
      entityManager.persist(customer);
    • remove(Object entity):将实体的状态从持久化状态变为删除状态,并从数据库中删除相应的记录。

      //实体不能是游离态的,否则会抛出异常,例如以下就是不行的
      // Customer c = new Customer();
      // c.setId(2);
      // entityManager.remove(c);
      Customer customer = entityManager.find(Customer.class, 2);
      entityManager.remove(customer);
    • merge(T entity):用于处理 Entity 的同步。即数据库的插入和更新操作。

      JPA API与注解

    此外 EntityManager 还有一些其他的方法,实际用到了再查阅吧。

  • EntityTransaction:事务管理类,有以下一些方法:

    • begin():启动一个事务
    • commit():提交一个事务
    • rollback():回滚一个事务。
    • isActive():查看当前事务是否是活动的,若为 true,则不能调用 begin()开启事务。

扩:实体的状态

  • 新建状态:新创建的对象,尚未拥有持久化主键。
  • 持久化状态:有持久化主键并和持久化建立了上下文环境。
  • 游离状态:有持久化主键,但是没有和持久化建立上下文环境。
  • 删除状态:拥有持久化的主键并和持久化建立了上下文环境,但是已从数据库中删除。

注:在这里,建立上下文环境就是与 EntityManager 关联。

二、JPA 注解

下面就来介绍些 JPA 中常见的注解。

  • @Entity 注解:用于实体类声明语句之前,指出该 Java 类为实体类,并映射到指定的数据库表中。

    @Entity(name = "customers") // 将 Customer 类 映射到 cutomers 表中
    public class Customer {
  • @Basic 注解:表示实体类中的属性到数据表中字段的映射,对于没有任何标注的 getXxx()方法,默认就是@Basic。

    // 默认情况下,就是@Basic 注解,email 属性映射成表中的 email字段
    public String getEmail() {
    return email;
    }
  • @Column 注解:指定属性映射成表中的特定名字字段,即属性和表中字段不同名。

    //将lastName 映射成表中的 last_name 字段
    @Column(name = "last_name")
    public String getLastName() {
    return lastName;
    }
  • @Id 注解:用于将此属性映射成数据表中的主键列。该注解往往也和 @GeneratedValue 注解一起使用,用于标注生成主键的策略。

    // 表示 id 属性映射成数据表中的主键列,并使用自动递增的生成策略
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public Integer getId() {
    return id;
    }
  • @Transient 注解:表示该属性不映射数据表中的字段。若某个属性不是数据表中的字段,则必须加上此注解,因为 ORM 框架默认属性的注解为 @Basic。

  • @Temporal 注解:在核心的 Java API 中日期、时间的类型都是 Date,而在数据库中却有DATE,TIME TIMESTAMP 或者混用,所以若要精确日期或时间,就需要使用此注解。

    //映射到数据库中的birth字段形如 2018-06-02,不加该注解,表中字段形如2018-06-02 12:22:12
    @Temporal(TemporalType.DATE)
    public Date getBirth() {
    return birth;
    }