Active Record vs Data Mapper:差异、优缺点与选型
副标题 / 摘要 Active Record 把数据与持久化绑定在一起,Data Mapper 把持久化隔离为独立层。本文对比二者并给出选型建议。 目标读者 使用 ORM 的后端工程师 设计领域模型的开发者 需要做架构取舍的团队 背景 / 动机 项目变复杂时,持久化模型往往开始“侵入”业务逻辑。 理解 Active Record 与 Data Mapper 的差异,是避免架构污染的关键。 核心概念 Active Record:对象自己保存/加载(数据与持久化耦合) Data Mapper:持久化逻辑在独立映射层 领域模型纯度:业务模型是否被 ORM 污染 实践指南 / 步骤 小型项目可用 Active Record 复杂领域建议 Data Mapper 明确领域边界,避免 ORM 侵入 用 Repository 隔离持久化 测试业务逻辑时替换存储层 可运行示例 # Active Record 风格 class UserAR: def __init__(self, name): self.name = name def save(self): print("save", self.name) # Data Mapper 风格 class User: def __init__(self, name): self.name = name class UserMapper: def save(self, user: User): print("save", user.name) if __name__ == "__main__": UserAR("Alice").save() UserMapper().save(User("Bob")) 解释与原理 Active Record 简单直观,但把持久化耦合进领域模型。 Data Mapper 更复杂,但让业务逻辑更纯粹、更易测试。 ...