对多个 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)
}
}
我有多个类似的 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)
}
}