php dao类设计,DAO数据访问对象设计 - GoFrame官网 - 类似PHP-Laravel, Java-SpringBoot的Go企业级开发框架...
关于DAO数据访问对象设计其实是关于GoFrame框架工程化实践中比较重要一块设计。
DAO设计结合GoFrame的ORM组件性能和易用性都很强,可以极大提高开发和维护效率。看完本章节内容之后,小伙伴们应该能够理解并体会到使用DAO数据库访问对象设计的优点。
一、现有ORM使用示例
使用作者本厂的案例举例,本厂是互联网医疗企业,所以示例以医生相关接口做示例。需要提前说明的是,这里涉及到的源码只是方便演示的示例代码,并不是真正生产使用的源码。
1、需要定义模型
用户基础表(仅作演示,真实的表有数十个字段)
医生信息表(仅作演示,真实的表有上百个字段)
2、GRPC接口实现示例
一个简单的GRPC查询医生信息接口。
一个简单的GRPC数据查询接口
二、现有痛点描述
1、必须要定义tag关联表结构与struct属性,无法做到自动映射
表字段与实体对象属性名称之间原本就有一定的关联规则,没有必要定义和维护大量的tag定义。
大量非必要的tag定义,用于指定数据表字段到实体对象属性映射
2、不支持通过返回对象指定需要查询的字段
无法通过返回的对象数据结构指定查询字段,要么只能SELECT * ,要么只能通过额外的方法手动录入查询字段,效率很低下。
常见的SELECT *操作,无法根据接口对象指定查询字段
3、无法对输入对象属性名称进行自动字段过滤
定义了输入与输出数据结构,输出的数据结构已经包含我们需要查询的字段名称。开发者输入定义的返回对象,期望在查询的时候仅查询我需要的字段名称,多余的属性则不会执行查询,自动过滤掉。
4、需要创建中间查询结果对象执行赋值转换
查询结果不支持struct智能转换,需要额外定义一个中间model模型,再通过其他工具进行复制,效率低。
存在中间临时的模型对象,用于承接查询结果及返回结构对象赋值转换
5、需要提前初始化返回对象,不管有无查询到数据
这种方式不仅不优雅,对性能也有影响,还对GC不太友好。期望查询到数据时再自动创建返回对象,没有查询到数据时什么都不要做。
需要预先初始化返回对象,不管有无查询到数据
6、没有DAO对象封装操作
大部分的Golang初学者似乎都倾向于使用一个全局的DB对象,在查询的时候通过DB对象生成特定表的Model对象再执行CURD操作,这是一种面向过程的使用方式。这种方式并没有代码分层的设计可言,使得数据操作和业务逻辑高度耦合。
原始数据库对象操作方式,没有DAO封装
7、太多的字符串硬编码,例如表名和字段的硬编码
举个例子,userId这个字段假如一不小心写成了UserId或者userid,测试的时候如果没有完全覆盖到,在一定的条件下才触发查询操作,是不是会造成新的一场事故呢?
大量的字符串硬编码
8、不支持链路跟踪
ORM作为关键的功能组件需要支持conetxt传递,以便支持链路跟踪。目前无法传递链路信息,无法在日志中打印TraceId等链路信息字段。
9、不支持SQL日志输出
并且需要支持开关功能,当出现问题的时候可以定位到具体的SQL,并且可以在日志中看到具体的链路信息。
三、改进方案设计
1、查询结果对象无需特殊标签定义
2、支持根据指定对象自动识别查询字段,而不是全部SELECT *
3、支持根据指定对象自动过滤不存在的字段内容
4、使用DAO对象封装代码设计,通过对象方式操作数据表
5、DAO对象将关联的表名及字段名进行封装,避免字符串硬编码
6、无需提前定义实体对象接受返回结果,无需创建中间实体对象用于接口返回对象的赋值转换
7、查询结果对象无需提前初始化,查询到数据时才会自动创建
8、支持context输入,以便支持链路跟踪
9、支持SQL日志输出能力,支持开关功能
10、数据模型、数据操作、业务逻辑解耦,支持Dao及Model代码工具化自动生成,提高开发效率,便于规范落地
采用DAO设计改进后的代码示例
php dao类设计,DAO数据访问对象设计 - GoFrame官网 - 类似PHP-Laravel, Java-SpringBoot的Go企业级开发框架...相关推荐
- PHP设计模式--数据访问对象模式
最简单的Web部件和最复杂的在线电子商务Web站点具有一个共同点:它们都要处理数据.大量的编程都设计数据的访问和操作.随着Internet的发展.脸颊存储设备应用数据的大量增长.对分析论的更深入理解以 ...
- DAO数据访问对象(Data Access Object)
持久化是将程序中数据库在瞬时状态和持久状态间转换的机制JDBC是一种持久化的机制,将程序直接保存成文本文件也是持久化机制的一种实现 JDBC的封装: 原因: JDBC将程序中的数据持久化保存到MySQ ...
- Java数据访问对象模式
数据访问对象模式(Data Access Object Pattern)或 DAO 模式用于把低级的数据访问 API 或操作从高级的业务服务中分离出来.以下是数据访问对象模式的参与者. 数据访问对象接 ...
- Java Data Access Object Pattern(数据访问对象模式)
数据访问对象模式(Data Access Object Pattern)或 DAO 模式用于把低级的数据访问 API 或操作从高级的业务服务中分离出来.以下是数据访问对象模式的参与者. 数据访问对象接 ...
- PHP设计模式系列 - 数据访问对象模式
数据访问对象模式 数据访问对象模式描述了如何创建透明访问数据源的对象. 场景设计 设计一个BaseDao基类,实现数据库操作基本的一些query,insert,update方法 在实际使用的过程中,继 ...
- HTML5期末大作业:直播网站设计——仿在线媒体歪秀直播官网模板html源码(11个页面) HTML+CSS+JavaScript 期末作业HTML代码
HTML5期末大作业:直播网站设计--仿在线媒体歪秀直播官网模板html源码(11个页面) HTML+CSS+JavaScript 期末作业HTML代码 临近期末, 你还在为HTML网页设计结课作业, ...
- html期末作业代码网页设计 web网页设计实例作业 ——中国风文化传媒企业官网(6页) 简单网页设计作业 静态HTML文化主题网页作业
web网页设计实例作业 --中国风文化传媒企业官网(6页) 简单个人网页设计作业 静态HTML文化主题网页作业 常见网页设计作业题材有 个人. 美食. 公司. 学校. 旅游. 电商. 宠物. 电器. ...
- Java job interview:项目开发小组成员网站数据访问层设计
在前面简单描述了下服务层,SOA面向服务架构,架构设计-业务逻辑层,以及一些面面向设计原则理解和软件架构设计箴言.这篇博客我们将继续进入我们的下一层:数据访问层.无论你用的是什么开发模式或者是业务模式 ...
- 数据访问层设计(持久层架构设计)
1.在线访问[直接根据需要每次调用] 2.Data Access Object [感觉类似于自己写的数据访问层明天CAT,专门用来访问数据库的] 3.DataTransfer Object [感觉类似 ...
最新文章
- 使用python编写单元测试
- 009_Spring Data JPA一对一关系
- android 状态栏 背景色_技术一面:说说Android动态换肤实现原理
- java数组元素相加_数组元素相加
- 条件转移指令和无条件转移指令练习
- Win32-Application的窗口和对话框
- java输出object object_js控制台显示[object Object]问题
- python数据库操作批量sql执行_Python批量修改数据库执行Sql文件
- Unity 内置渲染管线、SRP、URP、HDRP区别
- macOS | 提取BDrip(封装格式为mkv)中视频与音频并重新封装为mp4
- 001Diamond学习001概述
- [vue3.x]实战问题--Extraneous non-props attributes
- 【LEACH协议】基于matlab实现无线传感器网络LEACH与DEEC协议
- GET /static/css/bootstrap.min.js.map HTTP/1.1“ 404GET /static/css/bootstrap.min.css.map HTTP/1.1“404
- 仿今日头条后台管理系统(三)
- ffmeg将多段视频合成一个视频
- 高通--PMIC修改(三)
- 大四 Java开发实习近一年 记录(每6至12月更新一次)
- BUUCTF-网鼎杯2020-青龙组-joker
- Github Page绑定至个人域名
热门文章
- 【VirtualBox】VirtualBox的桥接网络模式,为啥网络不稳定?
- Linux 格式化磁盘命令mkfs
- OCLint+Xcode 代码规范利器
- VS2010安装异常中断后无法安装的解决方法(安装时发生严重错误)
- 利用div的定位制作复杂的页面布局
- [密码学基础][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第12篇]椭圆曲线上的群理论是什么
- php全局cors,PHP开启CORS - slagga的个人页面 - OSCHINA - 中文开源技术交流社区
- 空间留言软件_电脑硬盘空间提示不足,原来还可以这么做,真是学到老活到老...
- 字符串之字符判断以及字母的大小写转换
- .net千万级数据导出_记一次解决docker下oracle数据库故障事例