spring data jpa(orm思想、hibernate、jpa概述、jpa基本操作)

332 阅读3分钟

ORM概述

ORM(Object-Relational Mapping) 表示对象关系映射。

ORM建立了实体类和数据库表之间的关系,从而达到操作实体类就相当于操作数据库表的目的。

为什么使用ORM

当实现一个应用程序时(不使用O/R Mapping),我们可能会写特别多数据访问层的代码,从数据库保存数据、修改数据、删除数据,而这些代码都是重复的。

使用ORM则会大大减少重复性代码。对象关系映射(Object Relational Mapping,简称ORM),主要实现程序对象到关系数据库数据的映射。

常见ORM框架

mybatis、hibernate、jpa

hibernate与jpa

JPA规范本质上就是一种ORM规范,注意不是ORM框架——因为JPA并未提供ORM实现,它只是制订了一些规范,提供了一些编程的API接口,但具体实现则由服务厂商来提供实现

111.png


JPA和Hibernate的关系就像JDBC和JDBC驱动的关系,JPA是规范,Hibernate除了作为ORM框架之外,它也是一种JPA实现。

JPA怎么取代Hibernate呢?JDBC规范可以驱动底层数据库吗?答案是否定的,也就是说,如果使用JPA规范进行数据库操作,底层需要hibernate作为其实现类完成数据持久化工作。

jpa主键生成策略

通过annotation(注解)来映射hibernate实体的, 基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue设定的.这里的@id和@GeneratedValue都是JPA的标准用法。

JPA提供的四种标准用法为TABLE,SEQUENCE,IDENTITY,AUTO。

具体说明如下:

IDENTITY 主键由数据库自动生成(主要是自动增长型)

用法:

@Id 
@GeneratedValue(strategy = GenerationType.***IDENTITY***)

private Long custId;

SEQUENCE:根据底层数据库的序列来生成主键,条件是数据库支持序列

    @Id 
    @GeneratedValue(strategy = GenerationType.SEQUENCE,
                   generator="payablemoney_seq") 
    @SequenceGenerator(name="payablemoney_seq", 
                   sequenceName="seq_payment") 

    private Long custId;

源码

    //@SequenceGenerator源码中的定义
    @Target({TYPE, METHOD, FIELD})  
    @Retention(RUNTIME) 
    public @interface SequenceGenerator { 

       // 表示该表主键生成策略的名称
       // 它被引用在@GeneratedValue中设置的“generator”值中
       String name(); 

       // 属性表示生成策略用到的数据库序列名称。
       String sequenceName() default ""; 

       // 表示主键初识值,默认为0
       int initialValue() default 0; 

       // 表示每次主键值增加的大小,例如设置1
       // 则表示每次插入新记录后自动加1,默认为50
       in* allocationSize() default 50; 

    }

AUTO:主键由程序控制

    @Id 
    @GeneratedValue(strategy = GenerationType.AUTO) 
    private Long custId;

TABLE:使用一个特定的数据库表格来保存主键

    @Id 
    @GeneratedValue(strategy = GenerationType.TABLE, 
            generator="payablemoney_gen") 
    @TableGenerator(name = "pk_gen", 
        table="tb_generator", 
        pkColumnName="gen_name", 
        valueColumnName="gen_value", 
        pkColumnValue="PAYABLEMOENY_PK", 
        allocationSize=1 
    )

    private  Long custId;

    //@TableGenerator的定义:
     @Target({TYPE, METHOD, FIELD})  
     @Retention(RUNTIME) 
     public @interface TableGenerator { 
      // 表示该表主键生成策略的名称
      // 它被引用在@GeneratedValue中设置的“generator”值中
     String name(); 

      // 表示表生成策略所持久化的表名
      // 例如,这里表使用的是数据库中的“tb_generator”。
      String table() default ""; 

      //catalog和schema具体指定表所在的目录名或是数据库名
      String catalog() default ""; 

      String schema() default ""; 

      // 属性的值表示在持久化表中,该主键生成策略所对应键值的名称。
      // 例如在“tb_generator”中将“gen_name”作为主键的键值
      String pkColumnName() default ""; 

      // 属性的值表示在持久化表中,该主键当前所生成的值
      // 它的值将会随着每次创建累加。
      // 例如,在“tb_generator”中将“gen_value”作为主键的值
      String valueColumnName() default ""; 

      // 属性的值表示在持久化表中,该生成策略所对应的主键。
      // 例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”
      String pkColumnValue() default ""; 

      //表示主键初识值,默认为0。
      int initialValue() default 0; 

      //表示每次主键值增加的大小,
      // 例如设置成1,则表示每次创建新记录后自动加1,默认为50。
      int allocationSize() default 50; 

      UniqueConstraint[] uniqueConstraints() default{}; 

    }

    //这里应用表tb_generator,定义为 :
    CREATE TABLE  tb_generator ( 
      id NUMBER NOT NULL, 
      gen_name VARCHAR2(255) NOT NULL, 
      gen_value NUMBER NOT NULL, 
      PRIMARY KEY(id) 
    )