sql – 如何将数据库行转换为结构体,在Go?
发布时间:2020-05-24 09:11:04 所属栏目:MsSql 来源:互联网
导读:假设我有一个结构体: type User struct { Name string Id int Score int} 和具有相同模式的数据库表。将数据库行解析为结构体最简单的方法是什么?我在下面添加了一个答案,但我不知道这是最好的答案。 去包装测试通常提供线索的做事情。例如,从 database/s
|
假设我有一个结构体: type User struct {
Name string
Id int
Score int
}
和具有相同模式的数据库表。将数据库行解析为结构体最简单的方法是什么?我在下面添加了一个答案,但我不知道这是最好的答案。 解决方法去包装测试通常提供线索的做事情。例如,从database/sql/sql_test.go,
func TestQuery(t *testing.T) {
/* . . . */
rows,err := db.Query("SELECT|people|age,name|")
if err != nil {
t.Fatalf("Query: %v",err)
}
type row struct {
age int
name string
}
got := []row{}
for rows.Next() {
var r row
err = rows.Scan(&r.age,&r.name)
if err != nil {
t.Fatalf("Scan: %v",err)
}
got = append(got,r)
}
/* . . . */
}
func TestQueryRow(t *testing.T) {
/* . . . */
var name string
var age int
var birthday time.Time
err := db.QueryRow("SELECT|people|age,name|age=?",3).Scan(&age)
/* . . . */
}
对于您的问题,将一行查询到一个结构中,将会转换为: var row struct {
age int
name string
}
err = db.QueryRow("SELECT|people|age,3).Scan(&row.age,&row.name)
我知道这与您的解决方案类似,但重要的是要显示如何找到解决方案。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
