1

在将结果转换为 JSON 之前,我不想使用结构。假设我有一些结果:

result, err := collection.Find(ctx, filter, options)

我可以在 docs 变量中收集所有结果,doc变量中收集最后一个结果:

    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,而无需使用任何结构:

var jsonDoc bson.M
err = bson.Unmarshal(doc, &jsonDoc)
return jsonDoc

我无法将文档转换为 JSON 并因此在我的 Rest 服务器中使用。

2019-01-17 更新:

我在我的 REST 服务器中使用这样的结果:

user.GET("/booking/customer/:id", func(c *gin.Context) {
    result := GetAllCustomerBookings(c.Param("id"))
    c.JSON(http.StatusOK, result)
})

所以它不能是一个循环值。问题:如何将 []bson.Raw 转换为 []byte 或 bson.Raw。假设现在我在数组的每个值中都有 {JSON}。我需要一个这样的 JSON:[{JSON}, {JSON}, ...]。

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

Nodejs 和 mongodb 等效:

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);
            }
        });
});
4

1 回答 1

0

此代码有效。经过几个小时的尝试并感谢好运,我设法解决了这个问题。也许有人会解释这个?

我使用bson.M和result.Decode ()而不是result.DecodeBytes () 而不是bson.Raw 现在我的输出与 nodejs 给我的输出相同。

 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
于 2019-01-17T19:22:32.820 回答