Gorm Scan to interface 用 interface 去接收值
一般来说我们 scan 的时候,都是确定用什么类型的变量去接收值的,比如 int32,string 等,但如果直接用一个 interface 去接收,会发生什么?
var db *gorm.DB
var res interface{}
db = db.Select("count(orders.id)").Table("orders").Where("XXXXX")
err := db.Row().Scan(&res)
switch res.(type) {
case int64:
...
case int32:
...
}
这个时候,符合我们对 count 结果的预期,res 是一个 int64 的类型。不过,当我们的 select 语句变为:
var db *gorm.DB
var res interface{}
db = db.Select("sum(orders.price)").Table("orders").Where("XXXXX")
err := db.Row().Scan(&res)
switch res.(type) {
case int64:
...
case int32:
...
}
这个时候,res 的类型居然是 []uint8
,内容是像 [51 48 48 52 48] 这样的东西,怎么也想不到是代表什么含义。后来在同事的灵光一闪下,觉得会不会是 ascii 码,然后一问 48 在 ascii 码里就是 0,瞬间明了了。
所以,直接 scan 到 interface,运气好的话会得到你想要的类型,运气不好的话 gorm 就会乱扫。还是用自己定义好的类型比较靠谱
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论