database - 在 gorm orm 上为 golang 中的微服务创建顶级包
问题描述
我们是一家初创科技公司。我们使用 Golang 作为微服务的主要语言,使用gorm
orm 作为连接PostgreSQL
数据库的接口。
目前我们有多个微服务,有多个开发人员在开发它们。然而问题是,由于有很多方法可以做一件事gorm
,每个人都用自己的方式在数据库上编写查询。所以有些人使用该.Table()
函数进行查询,而另一些人只是通过该函数来.Model()
计算表本身。
所以现在代码不是标准的,我们希望有一种标准的方式来对我们的数据库进行查询。我们认为,如果我们可以有一个像库这样的包,它提供 aorm
的接口供我们使用(这样如果我们想更改orm
或不使用任何我们不必更改所有代码)标准的方式,它解决了问题。
但是我们从来没有创造过这样的东西,我们基本上不知道如何解决这个问题,以及是否存在任何图书馆做过这样的事情?我们也在努力使用标准的方式在 Golang 中进行查询,所以如果你能分享你对如何开发这样一个甚至有可能被公开的系统的想法,我们将不胜感激。
解决方案
我认为包装像 gorm 这样复杂的东西是一项复杂的任务,如果你不清楚如何处理它,你最好避免这样做。
一般来说,我建议首先弄清楚你想要执行什么,然后才决定你想如何做到这一点,并牢记明确的要求。在您知道自己到底想做什么之前就使用工具是一种使事情变得更糟而不是更好的可靠方法。以下是您可以遵循的步骤:
从记录您的代码标准开始,并在代码审查中将人们指向他们,以防他们不遵守;
自动检查您可以正式检查到持续集成管道中的任何内容(GitHub Actions、GitLabCI、TravisCI、CircleCI 等);
当且仅当上述事情不起作用时,请考虑创建自己的包装器,该包装器将为开发人员强制使用特定的样式。
到最后一步,您应该已经对缺失的内容有一个相当不错的了解,然后弄清楚如何修复它会容易得多。
推荐阅读
- php - 如何更新 laravel 中的数据透视表?
- python - 为什么我不能使用 python 中的程序导入 file.dat(我只能从控制台进行)?
- mysql - 存储过程 sqlalchemy orm 会话失败
- css - 为什么 CSS 脉冲动画无法正常工作?
- javascript - 修改 javascript 以删除字符串
- java - Java Stream GroupBy 和 SummingInt
- python - 无法在 pyttsx3 中更改语音
- android - 如何创建类似于图像中的布局?
- python - SQL Full outer join or inner join
- javascript - 用循环替换多个if语句?