关于 DAO
数据访问对象设计其实是关于 GoFrame
框架工程化实践中比较重要一块设计。
DAO
设计结合 GoFrame
的 ORM
组件性能和易用性都很强,可以极大提高开发和维护效率。看完本章节内容之后,小伙伴们应该能够理解并体会到使用 DAO
数据库访问对象设计的优点。
信息
我每年都会来回重新审视这篇文章,看看是否可以删除一些地方。可是每次都倍感失望,因为这篇文章对当今现状仍旧适用。并且今年,我还新增了内容。
一、现有 ORM
使用示例
1、需要定义模型
用户基础表(仅作演示,真实的表有数十个字段)
医生信息表(仅作演示,真实的表有上百个字段)
2、 GRPC
接口实现示例
一个简单的 GRPC
查询信息接口。
一个简单的 GRPC
数据查询接口
二、现有痛点描述
1、必须要定义 tag
关联表结构与 struct
属性,无法做到自动映 射
表字段与实体对象属性名称之间原本就有一定的关联规则,没有必要定义和维护大量的 tag
定义。
大量非必要的 tag
定义,用于指定数据表字段到实体对象属性映射
2、不支持通过返回对象指定需要查询的字段
无法通过返回的对象数据结构指定查询字段,要么只能 SELECT *
,要么只能通过额外的方法手动录入查询字段,效率很低下。
常见的 SELECT *
操作,无法根据接口对象指定查询字段