当前位置: 首页 > 面试题库 >

使用mongo-go-driver将结果转换为不带结构的JSON

顾跃
2023-03-14
问题内容

在将结果转换为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服务器中使用result像这样:

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

问题答案:

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

取而代之的 bson.Raw 我用 bson.Mresult.Decode() 代替
result.DecodeBytes() 现在我有作为的的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


 类似资料:
  • 问题内容: 我正在尝试使用该包将Go结构转换为JSON,但我得到的只是。我敢肯定这是完全显而易见的,但我看不到。 然后,当我尝试运行它时,我得到以下信息: 问题答案: 您需要导出的字段,以便在包装可以看到它。将字段重命名为。 输出:

  • 问题内容: 我正在使用https://github.com/mongodb/mongo-go- driver ,目前正在尝试实现这种结构的部分更新 例如,如果我有 然后,我希望存储文档中唯一的“标题”字段将被更改。 我需要写类似 问题是我不想用或手动编码每个非空字段。我尝试使用但出现错误 无法为* models.NoteUpdate类型创建元素,请尝试使用bsoncodec.ConstructEl

  • 问题内容: 我想将mongo-go-driver中的 bson转换为json。 我应该小心处理,因为如果数据中存在则失败。 例如,我想将以下bson数据转换为json。 以下失败。 问题答案: 如果您知道BSON的结构,则可以创建一个实现和接口的自定义类型,并根据需要处理NaN。例: 如果您的BSON具有任意结构,则唯一的选择是使用反射遍历该结构,并将所有出现的NaN转换为类型(可能是如上所述的自

  • 我在MongoDB中有以下文档: 我正在使用scala代码中的mongo-scala-driver来查询服务器。如何将mapped_column转换为scala字符串变量?我尝试使用以下代码:

  • 我已经看到,当我们使用或时,JOOQ可以自动返回POJO 但是有可能将复杂查询的结果转换成多个POJO吗? 我测试了方法,它工作得很好。但我没有支持对象。

  • 问题内容: 我从JavaScript进行$ getJSON调用得到以下结果。如何在JavaScript中将start属性转换为正确的日期? [{“ id”:1,“ start”:“ / Date(1238540400000)/”},{“ id”:2,“ start”:“ / Date(1238626800000)/”}] 谢谢! 问题答案: 您需要从字符串中提取数字,并将其传递给Date : 这些