假设我有一个结构:
type User struct { Name string Id int Score int }
以及具有相同架构的数据库表。将数据库行解析为结构的最简单方法是什么?我在下面添加了一个答案,但我不确定它是最好的答案。
这是一种方法 - 只需在Scan函数中手动分配所有结构值。
Scan
func getUser(name string) (*User, error) { var u User // this calls sql.Open, etc. db := getConnection() // note the below syntax only works for postgres err := db.QueryRow("SELECT * FROM users WHERE name = $1", name).Scan(&u.Id, &u.Name, &u.Score) if err != nil { return &User{}, err } else { return &u, nil } }
Go 包测试通常提供有关做事方式的线索。例如,从database/sql/sql_test.go,
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,name|age=?", 3).Scan(&row.age, &row.name)
我知道这看起来与您的解决方案相似,但展示如何找到解决方案很重要。