gpt4 book ai didi

sql - 如何将数据库行转换为结构

转载 作者:IT老高 更新时间:2023-10-28 12:58:23 25 4
gpt4 key购买 nike

假设我有一个结构:

type User struct {
Name string
Id int
Score int
}

还有一个具有相同架构的数据库表。将数据库行解析为结构的最简单方法是什么?我在下面添加了一个答案,但我不确定它是不是最好的。

最佳答案

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)

我知道这看起来与您的解决方案相似,但展示如何找到解决方案很重要。

关于sql - 如何将数据库行转换为结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17265463/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com