首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用mongo-go驱动程序将结果转换为没有结构的JSON

使用mongo-go驱动程序将结果转换为没有结构的JSON
EN

Stack Overflow用户
提问于 2019-01-16 20:34:50
回答 1查看 3.3K关注 0票数 3

在将结果转换为JSON之前,我不想使用structs。假设我得到了一些结果:

代码语言:javascript
复制
result, err := collection.Find(ctx, filter, options)

我可以收集docs变量中的所有结果,以及doc变量中的最后结果:

代码语言:javascript
复制
    var doc bson.Raw
    var docs []bson.Raw    
    for result.Next(ctx) {
            document, err := result.DecodeBytes()
            if err != nil {
                log.Println(err)
            }
            doc = document
            docs = append(docs, doc)
        }

我可以轻松地将最后的结果转换为JSON,而无需使用任何结构:

代码语言:javascript
复制
var jsonDoc bson.M
err = bson.Unmarshal(doc, &jsonDoc)
return jsonDoc

我无法将docs转换为JSON并在Rest服务器中使用。

更新2019-01-17:

我在REST服务器中使用的结果如下:

代码语言:javascript
复制
user.GET("/booking/customer/:id", func(c *gin.Context) {
    result := GetAllCustomerBookings(c.Param("id"))
    c.JSON(http.StatusOK, result)
})

所以它不可能是一个通过值的循环。问题:如何将[]bson.Raw转换为[]字节或bson.Raw。让我们想象一下,现在在数组的每个值中都有{JSON}。我需要一个这样的JSON:{JSON},{JSON},.

使用nodejs更容易,因为我可以在一个JSON文档中发送所有记录。Go和mongodb驱动程序需要遍历所有记录,我不知道如何构建一个JSON文档。

Nodejs和mongodb等效:

代码语言:javascript
复制
router.get('/bookings/customer/:id', function (req, res, next) {
    db.Bookings.find({
        "booking.customer._id": {
            $eq: req.params.id
        }
    }).sort({
            "booking.arrival_date": -1
        },
        function (err, bookings) {
            if (err) {
                res.send(err);
            } else {
                res.json(bookings);
            }
        });
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-17 19:22:32

这个密码起作用了。经过几个小时的努力,并感谢好运,我设法解决了这个问题。也许有人会解释这事?

我使用的是result.Decode()、bson.m、和result.DecodeBytes(),而不是bson.Raw,现在我的输出与nodejs提供的输出相同。

代码语言:javascript
复制
 var docs []bson.M
    for result.Next(ctx) {
        var document bson.M
        err = result.Decode(&document)
        if err != nil {
            log.Println(err)
        }
        docs = append(docs, document)
    }
    return docs
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54224955

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档