前言:
此刻小伙伴们对“oracle函数生成主键”可能比较注重,朋友们都需要了解一些“oracle函数生成主键”的相关知识。那么小编也在网上搜集了一些有关“oracle函数生成主键””的相关文章,希望大家能喜欢,小伙伴们一起来学习一下吧!一:代理主键_主键自增1、identity
1、采用底层数据库本身提供的主键生成标识符,条件是数据库支持自动增长数据类型
2、该生成器要求在数据库中把主键定义成为自增长类型。适用于代理主键
2、increment_主键自增(了解)
1、由Hibernate自动以递增的方式生成唯一标识符,每次增量为1作为新主键值
2、只有当没有其它进程向同一张表中插入数据时才可以使用,不能在集群环境下使用
3、每次都会查询数据库最大的ID
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缓存中
特点:持久化状态对象的任何变化都会自动同步到数据库中
五:游离|托管状态(detached)
1、脱管态也称离线态或者游离态,当某个持久化状态的实例与Session的关联被关闭时就变成了脱管态
总结:有id,没有在session缓存中
六:查看3中状态特点:
1、save方法: 不能理解成保存.理解成将瞬时状态转换成持久状态的方法(创建ID)
2、主键自增 : 执行save方法时,为了将对象转换为持久化状态.必须生成id值.所以需要执行insert语句生成.
3、increment: 执行save方法,为了生成id.会执行查询id最大值的sql语句
七:状态的转换图
1、需要把数据同步到数据库中,将对应的对象转换为持久化状态
标签: #oracle函数生成主键