hibernate 复合主键 根据主键删除_hibernate 7大主键生成策略详解与对象状态

一:代理主键_主键自增

1、identity

1、采用底层数据库本身提供的主键生成标识符,条件是数据库支持自动增长数据类型

2、该生成器要求在数据库中把主键定义成为自增长类型。适用于代理主键

48c0a92ebcddb48dad7024795176c9fc.png
61015c7950a131f098d4f5e0f7c92204.png

2、increment_主键自增(了解)

1、由Hibernate自动以递增的方式生成唯一标识符,每次增量为1作为新主键值

2、只有当没有其它进程向同一张表中插入数据时才可以使用,不能在集群环境下使用

08b91744629c6b93519c3c468e1473a0.png

3、每次都会查询数据库最大的ID

5500913907d1d321517c229c37d411be.png

3、sequence(了解)

1、Hibernate根据底层数据库序列生成标识符。条件是数据库支持序列

2、Oracle中的主键生成策略.

4、hilo_主键自增(了解)

1、高低位算法(主键只增的原理).主键自增.由hibernate来维护

2、开发中不使用(目前数据库没有不支持序列化主键和)只增主键);

5、native(hilo+sequence+identity)

1、数据库对自动生成表示符的能力来选择identity、 sequence、hilo三种生成器中的一种,适合跨数据库平台开发

6、uuid

1、Hibernate采用128位的LA-JID算法来生成标识符。该算法能够在网络环境中生成唯一的字符串标识符

2、其UUID被编码为一个长度为 32位的十六进制字符串

3、主键类型必须为string 类型

二:自然主键

1、assigned_自然主键生成策略

1、hibernate不会管理主键值.由开发人员自己录入

三:瞬时状态(transient)

1、瞬时态也称为临时态或者自由态,瞬时态的实例是由new命令创建,开辟内存空间的对象

2、不存在持久化标识OID(相当于主键值),尚未与Hibernate sesslon关联,在数据库中也没有记录

3、瞬时状态的对象在内存中是孤立存在的,与数据库中的数据无任何关联,仅是一个信息携带的载体。

总结:没有id,没有在session缓存中

四:持久状态(persistent)

1、持久态的对象存在持久化标识OID,加入到了Session缓存中

2、并且相关联的Session没有关闭,在数据库中有对应的记录,每条记录只对应唯一的持久化对象

3、持久态对象是在事务还未提交前变成持久态的。

总结:有id,在session缓存中

特点:持久化状态对象的任何变化都会自动同步到数据库中

e96fdedfc39b2473edb2d838d874acd2.png

五:游离|托管状态(detached)

1、脱管态也称离线态或者游离态,当某个持久化状态的实例与Session的关联被关闭时就变成了脱管态

总结:有id,没有在session缓存中

六:查看3中状态

特点:

1、save方法: 不能理解成保存.理解成将瞬时状态转换成持久状态的方法(创建ID)

2、主键自增 : 执行save方法时,为了将对象转换为持久化状态.必须生成id值.所以需要执行insert语句生成.

3、increment: 执行save方法,为了生成id.会执行查询id最大值的sql语句

bdc7ff0585fee1ccf946ad614c6d3011.png
3c14d0c380dab205993ee46d0b48215f.png

七:状态的转换图

1、需要把数据同步到数据库中,将对应的对象转换为持久化状态

847f530ef64e239c219d8aec6d953653.png
fee88228ebe3e81a1e503a94d656f2c6.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值