gpt4 book ai didi

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

转载 作者:数据小太阳 更新时间:2023-10-29 03:20:51 25 4
gpt4 key购买 nike

我不想在将结果转换为 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);
}
});
});

最佳答案

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

我使用 bson.M 而不是 bson.Rawresult.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

关于json - 使用 mongo-go-driver 将结果转换为不带结构的 JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54224955/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com