在将结果转换为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);
}
});
});
答案 0 :(得分:0)
此代码有效。经过数小时的尝试,并祝您好运,我设法解决了这个问题。也许有人会解释这个?
我使用 bson.M 和 result.Decode()代替 bson.Raw ,而不是 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