登录
首页 >  Golang >  Go问答

使用 gorm orm 为 golang 微服务创建主要模块

来源:stackoverflow

时间:2024-02-22 12:24:27 153浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《使用 gorm orm 为 golang 微服务创建主要模块》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

我们是一家初创科技公司。我们使用 Golang 作为微服务的主要语言,并使用 gorm orm 作为连接到 PostgreSQL 数据库的接口。

目前我们有多个微服务,有多个开发人员正在处理它们。然而问题是,由于在 gorm 中做一件事的方法有很多种,所以每个人都用自己的方式在数据库上编写查询。因此,有些人使用 .Table() 函数进行查询,而另一些人则通过 .Model() 来计算表本身。

所以现在代码不是标准的,我们希望有一个标准的方法来对我们的数据库进行查询。我们想,如果我们可以有一个像库一样的包,它提供 orm 的接口供我们使用(这样,如果我们想更改 orm 或不使用任何内容,我们就不必更改所有代码)标准方式,它解决了问题。

但是我们从来没有创建过这样的东西,我们基本上不知道如何解决这个问题,是否存在做过这样的事情的库?此外,我们正在努力制定在 Golang 中进行查询的标准方法,因此如果您能分享您对如何开发这样一个甚至有可能公开宣布的系统的想法,我们将不胜感激。


解决方案


我们遇到了完全相同的问题,我们针对不同的应用程序和不同的数据库(postgresql、mysql 和 sqlite)使用 gorm

我们天真地决定使用我们所谓的 storage 接口来抽象 gorm,该接口或多或少具有任何 orm 所需的基本操作。它看起来像这样:

type Storage interface {
    Create(object interface{}) error
    Retrieve(object interface{}, queries ...Query) error
    Update(object interface{}) error
    Delete(object interface{}) error
}

在开发之初,它为我们提供了很好的服务,我们甚至可以使用普通文件来实现这个接口,它就可以工作。

但是

几个月后,我们开始注意到它的局限性。有些操作可以在 gorm 中完成,但我们无法使用我们的界面来完成。因此,显然,我们决定扩展界面以拥有更多功能。同样,这又为我们赢得了几个月的时间,直到我们意识到:拥有 gorm 的所有功能的唯一方法是为 gorm 提供的所有功能提供一个接口,这并不是我们开始编写此包的原因

由于这个接口随处可见,我们决定作为临时解决方案来扩展该接口并添加一个返回 gorm.db 对象的函数,以便我们可以直接再次使用它。

这个故事的寓意是,我强烈建议不要构建这样的界面。利用时间帮助开发 gormv2,根据这个 post 应该很快就会出来。

我认为包装像 gorm 这样复杂的东西是一项复杂的任务,如果你不清楚的话如何处理它,你最好避免这样做。

一般来说,我建议首先弄清楚您想要强制执行的内容,然后在考虑到明确的要求的情况下决定如何执行该操作。在你知道自己到底想做什么之前就抓住一个工具是一种可靠的方法,只会让事情变得更糟而不是更好。您可以按照以下步骤操作:

  1. 首先记录您的代码标准,并在代码审查时指出这些标准,以防他们不遵守;

  2. 自动检查您可以正式检查到持续集成管道中的任何内容(github actions、gitlabci、travisci、circleci 等);

  3. 当且仅当上述方法不起作用时,请考虑创建自己的包装器,该包装器将强制开发人员使用特定的样式。

    通过最后一步,您应该已经对到底缺少什么有了相当不错的了解,然后就可以更容易地找出如何修复它。

本篇关于《使用 gorm orm 为 golang 微服务创建主要模块》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>