登录
首页 >  Golang >  Go问答

使用Go的database/sql包进行数据库查询结果的扫描操作

来源:stackoverflow

时间:2024-03-08 22:21:24 107浏览 收藏

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

问题内容

我使用数据库/sql并定义映射到数据库表列(标记字段)的结构:

// users ...
type users struct {
    id            int64  `field:"id"`                      
    username      string `field:"username"`           
    password      string `field:"password"`           
    tel           string `field:"tel"`                   
}

然后我查询:

rows, err := db.Query(sql)  // select * from users
        if err != nil {
            fmt.Println(err)
        }
        defer rows.Close()
        for rows.Next() {
            user := new(Users)

            // works but I don't think it is good code for too many columns
            err = rows.Scan(&user.ID, &user.Username, &user.Password, &user.Tel)

            // TODO: How to scan in a simple way 


            if err != nil {
                fmt.Println(err)
            }
            fmt.Println("user: ", user)
            list = append(list, *user)
        }
        if err := rows.Err(); err != nil {
            fmt.Println(err)
        }

正如您在 rows.scan() 中看到的,我必须编写所有列,而且我认为这对于 20 或更多列来说不是一个好方法。

如何清晰地扫描。


解决方案


这是使用反射的一个好习惯:

for rows.next() {
        user := users{}

        s := reflect.valueof(&user).elem()
        numcols := s.numfield()
        columns := make([]interface{}, numcols)
        for i := 0; i < numcols; i++ {
            field := s.field(i)
            columns[i] = field.addr().interface()
        }

        err := rows.scan(columns...)
        if err != nil {
            log.fatal(err)
        }
        log.println(user)
    }

您可以考虑使用jmoiron的sqlx包。它支持分配给结构。

自述文件摘录:

type Place struct {
    Country string
    City    sql.NullString
    TelCode int
}
 places := []Place{}
 err = db.Select(&places, "SELECT * FROM place ORDER BY telcode ASC")
 if err != nil {
     fmt.Println(err)
      return
 }

今天关于《使用Go的database/sql包进行数据库查询结果的扫描操作》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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