zoukankan      html  css  js  c++  java
  • 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

           

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

     

     

     

  • 相关阅读:
    灵活的JavaScript(一)
    菜鸟快飞之JavaScript对象、原型、继承(三)
    菜鸟快飞之JavaScript对象、原型、继承(二)
    菜鸟快飞之JavaScript对象、原型、继承(一)
    undo清理 &redo 持久化
    mysql执行计划分析
    mysql5.6的统计信息
    pt-online-schema-change原理分析
    校验主从数据并修复
    使用伪master+binlog恢复数据
  • 原文地址:https://www.cnblogs.com/wufengtinghai/p/entitiykey.html
Copyright © 2011-2022 走看看