• JBPM对象主键生成机制


       什么是主键

                  我们在建立数据库的时候,需要为每张表指定一个主键,所谓主键就是能够唯一标识表中某一行的属性或属性组,一个表只能有一个主键,但可以有多个候选索引。因为主键可以唯一标识某一行记录,所以可以确保执行数据更新、删除的时候不会出现张冠李戴的错误。当然,其它字段可以辅助我们在执行这些操作时消除共享冲突,不过就不在这里讨论了。主键除了上述作用外,常常与外键构成参照完整性约束,防止出现数据不一致。所以数据库在设计时,主键起到了很重要的作用。

          主键生成的方式

    1.       自动增长型字段

    由数据库生成主键字段,使用简单,但是对于外键关联、数据复制等不能很好的处理。

           2 .  手动增长型字段

              通过一张单独的表存储生成的主键,手动生成主键。保证了数据的正确性,但是增

    加了往返的数据库访问,并且要自己处理并发。

    3.       使用Guid

    Guid可以保证数据的唯一性,但是其占据的空间比较大,效率不高,同时生成的主键也没有固定的顺序可言。

    4.       使用“COMBCombine类型

    guid的后6给字节改成该guid生成的时间,这样既保证了主键的唯一,也保证了主键的顺序性!

      JBPM主键生成方式

           Jbpm没有使用hibernate的主键生成机制,而是自己实现的手动增长型字段。

           Jbpm的主键分为两种情况,为数据库持久化实例生成dbid和为Execution生成ID

          IdComposer:Execution生成Id的基类

           DbidGenerator:为数据库持久化实体类生成主键dbid

           DatabaseDbidGenerator:将最大值保存到数据库中

           DatabaseIdComposer:通过数据库持久化相关对象的数据为Execution生成

    Id

           

           并发访问处理将主键的获取放到事务中进行处理,这样保证了数据的锁定,同时赋予进程三次重试机会,并等待一定时间后进行重试。

     

     

     

  • 相关阅读:
    Linux内核参数优化
    Linux:文件系统层次结构标准(Filesystem Hierarchy Standard)
    全球海底光缆及我国海底光缆分布
    CentOS单网卡绑定双IP
    Weblate 2.11安装配置文档
    Docker安装及常用命令
    好文要保存
    rsh命令配置于使用
    RHEL(或CentOS)中关于逻辑卷( Logical Volume Manager,LVM)的一些概念及使用LVM的例子
    git学习资料
  • 原文地址:https://www.cnblogs.com/wufengtinghai/p/entitiykey.html
Copyright © 2020-2023  润新知