go 每一个数据库库使用起来都不太方便,有木有

2022-12-29 08:20:04 +08:00
 fxjson

感觉没有一个方便好用的库,每一个都有使用的痛点,gorm 查询返回 error 中记录不存在也会返回 error,导致每处的查询的 error 都要做是不是记录不存在的特殊判断;sqlx 原生 sql,比较喜欢,又没有单表增删改查的封装,也很通。不知道大家有木有这样的感觉,有没有推荐的库

4251 次点击
所在节点    Go 编程语言
22 条回复
yuanxin1999
2022-12-29 08:37:50 +08:00
用过 ent ,可以看看能不能击中你的甜点
licoycn
2022-12-29 09:08:46 +08:00
基本上 gorm/sqlx 都会返回 NotFoundError ,需要你自己用 errors.is 来判断
Bluelion
2022-12-29 09:49:25 +08:00
@licoycn 你用 find 不就好了,没有也不会 NotFoundError ,可以再看看文档
to2false
2022-12-29 09:57:28 +08:00
可以尝试用泛型包一层判断,确实不咋好用

```go
func ErrRecordNotFound[T any](err error) (*T, error) {
if errors.Is(err, gorm.ErrRecordNotFound) {
return new(T), nil
}

return nil, err
}
```
licoycn
2022-12-29 10:05:22 +08:00
@Bluelion 好像是有,最近写 go 比较少忘记了都
loneybw
2022-12-29 10:16:22 +08:00
https://github.com/YLonely/sqldb
自荐一下,写得不好多见谅
loneybw
2022-12-29 10:23:01 +08:00
darksword21
2022-12-29 10:26:59 +08:00
个人觉得目前没有好用的,或者说自己稍微写一下也可以用的不错
securityCoding
2022-12-29 10:35:42 +08:00
go 就是这个尿性,redis 也是这样 ErrNil
y0bcn
2022-12-29 10:53:55 +08:00
@securityCoding 说的太对了
EscYezi
2022-12-29 13:36:06 +08:00
fxjson
2022-12-29 13:42:00 +08:00
@Bluelion 那这样又怎么区分出来实体没有查询出结果,引用对象又不是 nil,很恶心
fxjson
2022-12-29 13:42:51 +08:00
@securityCoding java 这方面就很好,实体找不到记录返回 null
securityCoding
2022-12-29 16:15:20 +08:00
@fxjson java 也要判断 null ,go 只是习惯用 err 适配
hopingtop
2022-12-29 16:41:19 +08:00
xorm.io/xorm 我印象中,是没有 空返回 error ,exists, error := .Get(&struct{}) 不存在 exists 是 false
fxjson
2022-12-29 18:52:07 +08:00
@securityCoding java 只需要根据是不是 null 就好了,但是 go 要判断 error 并且其他 error 和 recordnotexist error 处理逻辑还不一样
rekulas
2022-12-30 11:13:14 +08:00
gorm 的 NotFoundError 这点确实很脑残,很多人都诟病,把业务错误跟服务错误都搞混了作者还坚决不改,只能自己判断下

gorm 不少地方使用起来都非常不方便,实在不明白为什么这么受人推崇 举个例子
指定字段是 Select("col1", "col2")而不是 Select("col1,col2")就非常反直觉,跟其他各种库包括数据库习惯都不一样

不过 gorm 的关联比其他库强大一点,可以灵活的实现各种关联模型

除了 gorm ,我比较推荐 xorm ,用起来也很不错
fxjson
2022-12-30 19:13:19 +08:00
@rekulas gorm 不少地方使用起来都非常不方便,实在不明白为什么这么受人推崇,我也有此疑惑
lesismal
2023-01-04 16:45:41 +08:00
试试我这个呀:
https://github.com/lesismal/sqlw

我也喜欢原生,但是 sqlx 那些也并不好用,所以按照自己喜欢的方式撸了个

旧帖:
https://www.v2ex.com/t/861739

也欢迎关注我的其他库:
https://www.v2ex.com/t/794435#reply4
lesismal
2023-01-04 16:54:40 +08:00
其他那些功能太多了,涉及到的细节处理也多。
我的库主要就是在 std 基础上封装了反射的部分,rawsql 能用的部分依旧能用,封装过的 sqlw.DB 提供了一点便捷的方法,让用户减轻结构体与传参、结果绑定部分的工作量,如果熟悉标准库的 rawsql ,不需要去学习其他那些库的基础只是、看下例子就懂了
话说,我就是因为其他库太复杂了,学不懂 /动,所以一直使用 rawsql ,后来写了这个,省力多了

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

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

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

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

© 2021 V2EX