首先:我是golang的新手,所以我可能不太了解。 我的任务是使用“gorp”从一个数据库中编写一个 Go 数据提取器。问题出在一张表上,该表具有自定义字段“TimeRange”。 它被定义为:
type TimeRange struct {
From string
To string
}
遗憾的是,当我尝试获取行时出现扫描器错误,所以我意识到我需要一个自定义扫描器。
// Scan - Implement the database/sql scanner interface
func (tr *TimeRange) Scan(value interface{}) error {
tr.From = "mis"
tr.To = "lala"
fmt.Printf("%v\n", *tr)
return nil
}
所以我希望在返回的字符串中看到固定的 '{mis lala}'。 为什么我得到:
var q2 []models.Dashboard
result, err := dbmap.Select(&q2, "select * from dashboard where id=3")
fmt.Printf("q2=%v\n", q2)
打印:
p2=[{{<nil> Tomek b1f6f0ba-f618-00d6-6d24-8410a9219c95}}]
这是: 时间范围、用户名和 UUID
可能很重要:使用“gorp”进行数据库管理
最佳答案
扫描函数将在传递给 dbmap.Select()
的值类型时调用,因此在您的情况下,您需要将 Dashboard
实现为 scanner
.
关于Go Scanner 仍然返回 <nil>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57665357/