1.JPA主键生成策略
1.1 概念
主键是关系型数据库中的一个基本概念,它用来保证记录的唯一性。同一个表中,不允许存在多条相同主键的记录。简单的说就是具有自增、非空且唯一的特性。
1.2 JPA标准主键生成策略
- auto:自动根据方言来选择表主键生成(默认)
- table:表的生成策略,会另外创建一张表来维护主键,兼容性比较好 性能麻烦(一般不用)
- sequence:序列策略
- identity:自增策略
1.3 主键的分类
自然主键:具有实际业务意义的列作为为主键,比如身份证号码
代理主键:没有实际意义的列作为主键,比如 id(推荐)
2. JPA持久对象的状态
2.1 JPA的状态
新建状态、临时状态、瞬时状态:刚刚创建出来的对象,还没有和EntityManager发生关系;
持久状态、托管状态:和EntityManager发生关系、比如调用persist merge等方法;
游离状态、脱管状态:脱离EntityManager管理,比如clear,close,commit提交之后
删除状态:计划要准备删除的时候,remove之后