Active Record 的限制与缺陷:为什么它不适合复杂领域
副标题 / 摘要 Active Record 让开发变快,但在复杂领域模型中常会失控。本文解释其限制与替代思路。 目标读者 使用 ORM 的后端工程师 设计领域模型的团队 关注架构演进的技术负责人 背景 / 动机 Active Record 把数据与行为放在同一个类中,适合简单 CRUD。 当业务复杂时,领域逻辑会被持久化细节污染。 核心概念 Active Record:模型自带持久化行为 领域模型污染:业务逻辑与数据访问耦合 事务边界:难以清晰控制 实践指南 / 步骤 识别业务复杂度与规则数量 评估是否需要明确的领域层 复杂场景考虑 Data Mapper 将持久化逻辑下沉到仓储层 可运行示例 # Active Record:模型自带保存逻辑 class User: def __init__(self, name): self.name = name def save(self): # 这里直接访问数据库 return f"save {self.name}" if __name__ == "__main__": u = User("Alice") print(u.save()) 解释与原理 Active Record 的优点是简单直接,但会让业务逻辑与持久化高度耦合。 当规则变复杂时,测试与演进成本显著上升。 常见问题与注意事项 Active Record 真的不适合大型系统吗? 并非绝对,但复杂业务会更难维护。 是否必须迁移到 Data Mapper? 只有在复杂规则与多聚合情况下才建议。 ...