Gopher 我们一起来造个 ORM 吧!

2022-07-21 11:36:29 +08:00
 wenjie0032

可能绝大部分搞业务的同学逃不过 CRUD, 在编程中会有大量的工作与数据库打交道

常见的解决方案一般有以下三种, 1. 原生手写, 2. 开源 orm 类库, 3. 自研 orm 类库

诉求不同方案也就不同, 开发者在 高性能易用性 之前来回权衡, 做出符合自己实际情况的选择.

已经有很多优秀的开源库了 awesome-go-orms, 发起这个小活动的目的

  1. 学习如何设计一个对外 API 稳定的开源库
  2. 设计开源库时保持 api 稳定的情况下如果兼顾可扩展性 (自定义类型, Trace, Logger 等等)
  3. 数据模型抽象, 数据可能保存在 MySQL, MongoDB, Es 等不同的 BD, 甚至是三方 API 如果统一支持?
  4. 多跟优秀的人交流(比如正在看帖的你), 见贤思齐.

我们的思考方式: 我希望能支持 xxx, 这样做的好处是 xxx, 这样做有什么坏处吗, 其他项目是怎么实现的?

比如:

  1. 我希望能自动构造 SQL 语句, 这样做能灵活控制 SQL 条件, 避免硬编码, 坏处可能是出问题了不好定位 sql...
  2. 我希望能查询条件可以是 method(args ...WhereOption) 的形式, 这样做可以根据请求中的参数动态构造约束, 对比链式调用的优势是..., 缺点是...

业余也根据以上方式实践了下 fly, 反复修改了很多次, 也尝试了泛型 /反射等的使用, 有很多地方还没有想清楚, 比如数据模型的描述上, 是用 Options 的模式, 还是 Struct tag 的模式, 优劣是什么 等, 这是一个纯学习性的讨论活动, 有兴趣的大佬们进群一起讨论吧.

这是企微群, 个人微信也可以直接加入, 企微主体是 "爱码士", 我自己建的😂 用这个主要图他这个二维码是活码(其实就是一个中转页面, 进入后出现的那个是系统自动生成的当前可用的群二维码), 不会有 7 天过期(希望帖子能活到 7 天后😝)

6003 次点击
所在节点    Go 编程语言
39 条回复
lesismal
2022-07-21 23:12:06 +08:00
@join 我这个也不是只支持 mysql 呀,主要是为了方便标准库 sql 与结构体的映射,并不限制用哪个 driver 。但我不是每个数据库都测了,目前 mysql 和 postgres 是可以的,如果 oracle 、sqlserver 或者其他的数据库有问题(应该只是占位符不一样会导致拼接的 sql 语句错误),我可以继续做兼容。

另外,不知道兄台多大年纪,但我也已经不是小伙子了。
lesismal
2022-07-21 23:13:53 +08:00
@lesismal #21
有兴趣的可以看下例子,再对比下 orm ,或者 sqlx 之类的,看看哪个好用。
LeegoYih
2022-07-22 01:17:45 +08:00
受限于 Go 语言本身,注定就没有好用的 ORM 框架
realpg
2022-07-22 02:54:12 +08:00
等手头项目做完 计划做一个开源轻量查询拼接器,轻 orm

喷了那么久的 gorm, 不打算总打嘴炮
Trim21
2022-07-22 02:58:50 +08:00
@EminemW 优化 select 是指只 select 用到的字段?这个在 gorm.DB 初始化的时候有一个 SelectFileds 的设置
Trim21
2022-07-22 03:00:38 +08:00
SQLboiler 看的 API 起来挺舒服,可惜不支持我现在的使用场景,我有几个表恰好他不支持…
Aloento
2022-07-22 03:56:40 +08:00
@Trim21 捕获 Trim 大佬
Aloento
2022-07-22 03:58:11 +08:00
真的要整好的 ORM 我只认可 EF Core ,其他的我还不如写 pg/SQL 还跟舒服些
bthulu
2022-07-22 08:09:32 +08:00
@Aloento efcore 真是垃圾中的垃圾, deleteById 这样的方法都没有, 必须先通过 id 查出来, 再删除, 脱裤子放屁最在行
cbasil
2022-07-22 09:37:12 +08:00
手写 sql 能有啥问题
wenjie0032
2022-07-22 09:51:45 +08:00
@seth19960929 , @lesismal , @kkkiio , @Trim21 , @Aloento 感谢评论区大佬们的推荐, 看下来比较喜欢 GoFrame 和 SQLboiler 的实现理念, orm 这种工具实在是重口难调😂, 从我了解到的情况来看, 大部分公司是自研或基于开源项目自研,
也许其中有很多结合自身情况的考量, 后续我会持续迭代个人项目 https://github.com/daodao97/fly, 最起码先自用比较舒服吧, 也算是一个学习积累的过程

额外: GoFrame 的文档写的真心不错, 点赞
rickiey
2022-07-22 10:15:45 +08:00
gorm 除了 Create 可以批量创建,其他全部手写 sql, raw 或 exec 执行,结果 Scan ,目前没问题,有时 update 时会用 map
tairan2006
2022-07-22 10:16:26 +08:00
ent 设计的不错,不过真用起来还是 sqlbuilder 一把梭
rickiey
2022-07-22 10:16:46 +08:00
其实我只需要一个能把结果自动映射到我的 go 结构体的框架就够了
mizuhashi
2022-07-22 13:11:11 +08:00
做之前建议先用用 rails 的 activerecord 体验一下
StarkWhite
2022-07-22 15:48:33 +08:00
@tairan2006 ent 是指 fb 新出的那个 orm 库吗?
tairan2006
2022-07-22 15:58:45 +08:00
@StarkWhite 嗯,对
StarkWhite
2022-07-22 17:00:58 +08:00
没用过,我用过 prisma, sequelize, typeorm 这些
Aloento
2022-07-22 20:31:17 +08:00
@bthulu 可以看看社区的扩展方法,你说的都在扩展方法里面实现了,建议多用用再来发言

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/867712

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX