在之前的章节 代码分层设计 有提及到”模型“的概念。

这一章节,我们集中介绍一下在GoFrame中关于模型的定义以及对应的管理。

一、数据模型

数据模型又叫做实体模型,主要是来自于底层持久化数据库的数据结构,例如:MySQLRedisMongoDBKafka等等。这部分数据结构是由第三方系统维护的,可以通过工具对其集合数据结构进行识别,并自动生化成对应的程序数据模型代码。这部分数据模型的代码位于/internal/model/entity目录下。开发者不需要手动在程序中维护数据模型,在GoFrame框架规范中,数据模型统一使用CLI工具统一维护,代码自动生成。

数据模型与业务模型 - 图1

数据模型示例

二、业务模型

业务模型主要包含两类:接口输入/输出模型业务输入/输出模型

接口输入/输出模型

接口输入/输出模型用于系统/服务间的接口交互,定义在api接口层中,供工程项目所有的层级调用,例如controller, logic, model中均可以调用api层的输入输出模型,但是api层仅用于与外部服务的接口交互,该模型中不能调用或者引用内部的模型如model模型。在GoFrame框架规范中,这部分输出输出模型名称以XxxReqXxxRes格式命名。

数据模型与业务模型 - 图2

接口输入模型示例

业务输入/输出模型

业务输入/输出模型用于服务内部模块/组件之间的方法调用交互,特别是controller->service或者service->service之间的调用。这部分模型定义在model模型层中。在GoFrame框架规范中,这部分输入输出模型名称通常以XxxInputXxxOutput格式命名。

数据模型与业务模型 - 图3

业务输入模型与业务输出模型示例

特殊的业务模型DO

GoFrame有一类特殊的业务模型DO,介于业务模型与数据模型之间,主要用于结合框架强大的ORM组件大大简便DAO数据访问操作。

数据模型与业务模型 - 图4

DO主要用于DAO数据访问操作

三、其他模型

还有内部私有的模型,用于模块内部调用,例如在logic各个业务模块内部定义的模型,用于内部逻辑,不对外公开。