标识域 Identify Field

  • 在对象中保存DB的ID字段,以维持内存对象和DB数据Row之间的identify.
    • 关系DB使用key来区分数据行.
    • 而内存对象不需要这样的键.因为对象系统能够保证身份确认.
    • 读取时没有问题,但是为了正确地写回DB.需要联系两者.
    • 本质上,只是将DB表的主键存储在对象的field上.
  • 工作机制
    • 键的选择
      • meaningful key.
        • 应保证唯一性和恒定性.
        • 而这种检查是滞后的(Data已经进入DB后才可行).
        • 所以它是不可信的.
      • meaningless key.
        • 由Db构造的,无用的随机数.
    • 简单/组合键
      • Simple键.只使用一个DB字段.优点是完全一致性(所有的键操作都可以使用相同的代码).
      • compound键.使用多个DB字段.
        • 当一个表与另一表上下文相关时易于使用.
        • 总是有意义的,所以需要注意其唯一性和恒定性.
    • 类型
      • 主要的键操作:相等性检查;得到下一个键.
      • 键的大小会影响性能,尤其是有索引时.
    • 唯一性
      • 表唯一.在处理继承时比较麻烦.
      • DB唯一.任何一个表的任何一个数据行都是唯一的.好处是可以使用一个单间的标识映射.
    • 对象内identify field的表示
      • 最简单的情况是于DB的键相匹配的域.
      • 对于组合键,最好建立一个键类.
    • 取得新键
      • DB自动生成
        • auto-generated field.
          • 每当插入一行Data时,该域自增1.
          • 问题是难以确定生成的新键的值.
          • 所以,对于需要插入关联对象的表不能使用它(插入订单Data时,需要它的键作为订单项目的外键).
      • GUID.
        • 安全的键.
        • 问题是结果串较长.有性能问题.
      • 自己产生
        • 小系统时,(select max)+1.
          • 会锁住整个表.并且需要保证事务间的独立性.否则会多个事务得到同一key.
        • 使用独立的键表.
          • 键表的两列:名称和下一个有效值.
          • DB唯一键.表里只有一行.
          • 表唯一键.Db的每个表对应键表中的一行Data.
          • 对键表的访问,应该置于对其他表插入更新的事务之外的独立事务中.
            • 这样允许一创建内存对象就立刻得到ID.其它业务事务可以立刻使用.
            • 问题是当回滚了插入操作时,操作对应的键就被废弃了.
  • 使用时机
    • 在内存对象与DB行之间存在映射关系时需要使用identify.通常在领域模型或行数据入口的情况下.
原文地址:https://www.cnblogs.com/robyn/p/3522206.html