微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 如何将数据库行转换为结构体,在Go?

假设我有一个结构体:
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)

我知道这与您的解决方案类似,但重要的是要显示如何找到解决方案。

原文地址:https://www.jb51.cc/mssql/84611.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐