登录
首页 >  Golang >  Go问答

使用结构体进行批量 SQL 查询

来源:stackoverflow

时间:2024-02-08 19:24:24 481浏览 收藏

大家好,我们又见面了啊~本文《使用结构体进行批量 SQL 查询》的内容中将会涉及到等等。如果你正在学习Golang相关知识,欢迎关注我,以后会给大家带来更多Golang相关文章,希望我们能一起进步!下面就开始本文的正式内容~

问题内容

我有多个类似的 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 查询》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>