对多个 SQL 查询使用一个结构

Use one struct for multiple SQL queries

我有多个类似的 SQL 查询需要在 Go 代码中 运行。
像这样:

type S1 struct {
    X int
    Y int
    Z string
}

rows, err := db.Queryx("SELECT X,Y,Z FROM SomeTable")
for rows.Next() {
    var p S1
    err = rows.StructScan(&p)
}
 
type S2 struct {
    Y int
    Z string
}

rows, err := db.Queryx("SELECT Y,Z FROM SomeTable")
for rows.Next() {
    var p S2
    err = rows.StructScan(&p)
}

type S3 struct {
    X int
    Y int
}

rows, err := db.Queryx("SELECT X,Y FROM SomeTable")
for rows.Next() {
    var p S3
    err = rows.StructScan(&p)
}

有没有办法对所有 3 个查询使用一个结构?
理想情况下 S1 用于所有 3 个查询会很棒。
也许这很重要,正在使用 Clickhouse 数据库。
SqlX 文档并不暗示这是可能的,因此在我尝试自己解决问题时出现了这个问题...

答案取自此处:https://go.dev/doc/database/querying#multiple_rows

使用 Scan 方法,您可以为查询结果的每个查询列分配填充一个变量。

注意:未由 scan() 填充的值将默认为字段类型的零值。

type S1 struct {
    X int
    Y int
    Z string
}

func run() {
    rows, err := db.Queryx("SELECT X,Y,Z FROM SomeTable")
    for rows.Next() {
        var p S1
        err = rows.Scan(&S1.X, &S1.Y, &S1.Z)
    }

    rows, err := db.Queryx("SELECT Y,Z FROM SomeTable")
    for rows.Next() {
        var p S1
        err = rows.Scan(&S1.Y, &S1.Z)
    }

    rows, err := db.Queryx("SELECT X,Y FROM SomeTable")
    for rows.Next() {
        var p S1
        err = rows.Scan(&S1.X, &S1.Y)
    }
}