登录
首页 >  Golang >  Go问答

能否将Couchbase N1QL查询结果直接映射到Go中

来源:stackoverflow

时间:2024-03-21 08:45:31 137浏览 收藏

使用 N1QL 查询 Couchbase 时,将查询结果直接映射到 Go 结构中存在限制。使用通配符(*)选择所有元素时,映射无法进行。然而,通过显式指定每个字段,映射可以成功执行。

问题内容

当我通过使用 * 运算符选择所有元素来实现查询时,查询不会映射到结构。

query := gocb.newn1qlquery("select * from `item-bucket` where itembarcode=$1")
queryparams = append(queryparams, itembarcode)
rows, err := itembucket.executen1qlquery(query, queryparams)

var row itementity
for rows.next(&row) {
    fmt.printf("results: %+v\n", row)
}

但是,当我将每个字段添加到查询中时,它会直接映射。

query := gocb.NewN1qlQuery("SELECT itemBarcode, color, price FROM `item-bucket` WHERE itemBarcode=$1")
queryParams = append(queryParams, itemBarcode)
rows, err := itemBucket.ExecuteN1qlQuery(query, queryParams)

var row ItemEntity
for rows.Next(&row) {
    fmt.Printf("Results: %+v\n", row)
}

有没有办法使用 * 运算符直接映射到结构体?

该项目的go版本为1.6


正确答案


查看 sqlx,其中的自述文件包含使用 select * from x 等查询的示例。如果您的数据库列名称与结构字段名称不直接匹配,您可以将它们指定为结构标签,例如:

type ItemBucket struct {
    ItemBarcode string `db:"itemBarcode"`
    Color       string `db:"last_name"`
    ...
}

终于介绍完啦!小伙伴们,这篇关于《能否将Couchbase N1QL查询结果直接映射到Go中》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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