设计模式-标识映射(Identity Map)

概念

通过在映射中保存每个已经加载的对象,确保每个对象只加载一次。当要访问对象的时候,通过映射来查找他们。

从数据库加载对象时,对象与其映射的一致性、重复加载,这些都是需要得到保证的。

标识映射记录在一个业务事务中从数据库读出的所有对象。无论什么时候要用一个对象,先检查标识映射,看需要的对象是否已经在内存中

运行机制

标识映射最基本的思想是使用一系列映射,包含了从数据库读出的对象。由于需要与并发管理交互,还应该考虑使用乐观离线锁。

相关问题:

  • 键选择。数据库表的主键作为映射的键。
  • 确定显示的还是通用的标识映射设计。显示的标识映射为每一种需要的对象提供不同的方法,如findPerson(1),通用的则利用参数指出所需的对象类型,如findPerson("person",1)。
  • 数量。当数据库有唯一键时整个会话对应一个映射,否则采用多映射,即每个类或每个表对应一个映射。
  • 标识映射的位置。若使用回话则放到某个特定的会话对象中,若使用工作单元则放到工作单元中。

使用时机

标识映射除了保证内存对象和数据库记录间映射的一致性外,还可以作为高速缓存-对某数据的访问不需要每次都和数据库交互。

不需要标识映射的情形:

  • 用对象数据库作为事务高速缓存,可以提高性能。
  • 在所有条件下都为只读的对象。
  • 对依赖映射不需要建立标识映射。关联对象的存在受父对象控制,没有必要用映射保存标识,关联对象对应数据库中主表-细表的关系。
  • 标识映射在超出会话的情况下不起作用。

示例

相关推荐
eWidget2 分钟前
核心业务系统国产化:如何破解 Oracle 迁移中的“重构代价”与“性能瓶颈”?
数据库·oracle·重构·kingbase·数据库平替用金仓·金仓数据库
lhxsir3 分钟前
oracle常用命令(DBA)
数据库·oracle·dba
Elastic 中国社区官方博客5 分钟前
Elasticsearch 8.17.2 升级到 9.2.4 完整升级过程
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索·运维开发
Re.不晚8 分钟前
Redis事务
数据库·redis·php
C澒8 分钟前
从单体到分布式:SLDS 2.0 全球物流履约网络架构演进之路
前端·分布式·架构·系统架构·教育电商·交通物流
数据知道9 分钟前
PostgreSQL:如何定期验证备份的有效性?(灾备演练)
数据库·postgresql
档案宝档案管理11 分钟前
档案管理系统软件:档案宝让企业实现高效档案利用与精准数据分析
大数据·数据库·人工智能·档案·档案管理
彷徨的蜗牛12 分钟前
架构设计终极指南:从选型博弈到演进路线
架构·系统架构
a35354138213 分钟前
设计模式——访问者模式
设计模式·访问者模式
eWidget14 分钟前
核心业务系统“去O”实战:如何破解语法兼容与逻辑重构难题?核心业务系统“去O”实战:如何破解语法兼容与逻辑重构难题?
数据库·oracle·重构·kingbase·数据库平替用金仓·金仓数据库