为什么我从 mongodb 中获取 json 中某些字段的全零值?
Why am I getting all zero value for certain field in my json from mongodb?
我正在使用官方 mongodb-go-driver 从 Go 网络服务器中的 MongoDB atlas 获取我的数据。我正在使用 json.Marshal 转换为 json。但某些字段的所有值都变为零。
package main
import (
"context"
"fmt"
"log"
"github.com/gin-gonic/gin"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
"go.mongodb.org/mongo-driver/mongo/readpref"
)
var c = GetClient()
type PlantData struct {
Minute int `json:"minute"`
Date int `json:"date"`
Moisture1 int `json:"moisture_1"`
Hour int `json:"hour"`
Month int `json:"month"`
Year int `json:"year"`
Humidity1 float64 `json:"humidity_1"`
Temperature1 float64 `json:"temperature_1"`
}
func GetClient() *mongo.Client {
clientOptions := options.Client().ApplyURI("MY_MONGODB_URI")
client, err := mongo.NewClient(clientOptions)
if err != nil {
log.Fatal(err)
}
err = client.Connect(context.Background())
if err != nil {
log.Fatal(err)
}
return client
}
func ReturnAllPlantsData(client *mongo.Client, filter bson.M) []*PlantData {
var plantsdata []*PlantData
collection := client.Database("iot").Collection("tomatos")
cur, err := collection.Find(context.TODO(), filter)
if err != nil {
log.Fatal("Error on Finding all the documents", err)
}
for cur.Next(context.TODO()) {
var plantdata PlantData
err = cur.Decode(&plantdata)
if err != nil {
log.Fatal("Error on Decoding the document", err)
}
plantsdata = append(plantsdata, &plantdata)
}
return plantsdata
}
func getting(g *gin.Context) {
plantsdatas := ReturnAllPlantsData(c, bson.M{})
ans, _ := json.Marshal(plantsdatas)
fmt.Println(string(ans))
c.String(200, string(ans))
}
func main() {
err := c.Ping(context.Background(), readpref.Primary())
if err != nil {
log.Fatal("Couldn't connect to the database", err)
} else {
log.Println("Connected!")
}
router := gin.Default()
router.GET("/data", getting)
router.Run()
}
我的预期输出:
[{
"minute": 3,
"date": 14,
"moisture_1": 96,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 77.2,
"temperature_1": 22.7
}, {
"minute": 8,
"date": 14,
"moisture_1": 96,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 78.1,
"temperature_1": 22.8
}]
实际结果:
[{
"minute": 3,
"date": 14,
"moisture_1": 0,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 0,
"temperature_1": 0
}, {
"minute": 8,
"date": 14,
"moisture_1": 0,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 0,
"temperature_1": 0
}]
分钟、小时、日期、月份和年份的值正确且未更改
但水分、湿度和温度的所有值都变为零。
从/到 MongoDB 编组时,您必须使用 bson
标记。 json
标签用于 encoding/json
包,Mongo 驱动程序不使用(忽略)它们。
type PlantData struct {
Minute int `bson:"minute"`
Date int `bson:"date"`
Moisture1 int `bson:"moisture_1"`
Hour int `bson:"hour"`
Month int `bson:"month"`
Year int `bson:"year"`
Humidity1 float64 `bson:"humidity_1"`
Temperature1 float64 `bson:"temperature_1"`
}
如果结构字段中缺少 bson
标签,MongoDB 中使用的默认名称将是以小写字母开头的结构字段名称,这就是某些(大多数)字段的原因匹配但不匹配 Moisture1
(它与 moisture_1
的区别不仅仅是首字母大写)。
如果您还想将 encoding/json
包与此结构一起使用,您可以同时提供:
type PlantData struct {
Minute int `bson:"minute" json:"minute"`
Date int `bson:"date" json:"date"`
Moisture1 int `bson:"moisture_1" json:"moisture_1"`
Hour int `bson:"hour" json:"hour"`
Month int `bson:"month" json:"month"`
Year int `bson:"year" json:"year"`
Humidity1 float64 `bson:"humidity_1" json:"humidity_1"`
Temperature1 float64 `bson:"temperature_1" json:"temperature_1"`
}
我正在使用官方 mongodb-go-driver 从 Go 网络服务器中的 MongoDB atlas 获取我的数据。我正在使用 json.Marshal 转换为 json。但某些字段的所有值都变为零。
package main
import (
"context"
"fmt"
"log"
"github.com/gin-gonic/gin"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
"go.mongodb.org/mongo-driver/mongo/readpref"
)
var c = GetClient()
type PlantData struct {
Minute int `json:"minute"`
Date int `json:"date"`
Moisture1 int `json:"moisture_1"`
Hour int `json:"hour"`
Month int `json:"month"`
Year int `json:"year"`
Humidity1 float64 `json:"humidity_1"`
Temperature1 float64 `json:"temperature_1"`
}
func GetClient() *mongo.Client {
clientOptions := options.Client().ApplyURI("MY_MONGODB_URI")
client, err := mongo.NewClient(clientOptions)
if err != nil {
log.Fatal(err)
}
err = client.Connect(context.Background())
if err != nil {
log.Fatal(err)
}
return client
}
func ReturnAllPlantsData(client *mongo.Client, filter bson.M) []*PlantData {
var plantsdata []*PlantData
collection := client.Database("iot").Collection("tomatos")
cur, err := collection.Find(context.TODO(), filter)
if err != nil {
log.Fatal("Error on Finding all the documents", err)
}
for cur.Next(context.TODO()) {
var plantdata PlantData
err = cur.Decode(&plantdata)
if err != nil {
log.Fatal("Error on Decoding the document", err)
}
plantsdata = append(plantsdata, &plantdata)
}
return plantsdata
}
func getting(g *gin.Context) {
plantsdatas := ReturnAllPlantsData(c, bson.M{})
ans, _ := json.Marshal(plantsdatas)
fmt.Println(string(ans))
c.String(200, string(ans))
}
func main() {
err := c.Ping(context.Background(), readpref.Primary())
if err != nil {
log.Fatal("Couldn't connect to the database", err)
} else {
log.Println("Connected!")
}
router := gin.Default()
router.GET("/data", getting)
router.Run()
}
我的预期输出:
[{
"minute": 3,
"date": 14,
"moisture_1": 96,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 77.2,
"temperature_1": 22.7
}, {
"minute": 8,
"date": 14,
"moisture_1": 96,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 78.1,
"temperature_1": 22.8
}]
实际结果:
[{
"minute": 3,
"date": 14,
"moisture_1": 0,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 0,
"temperature_1": 0
}, {
"minute": 8,
"date": 14,
"moisture_1": 0,
"hour": 23,
"month": "02",
"year": 2019,
"humidity_1": 0,
"temperature_1": 0
}]
分钟、小时、日期、月份和年份的值正确且未更改 但水分、湿度和温度的所有值都变为零。
从/到 MongoDB 编组时,您必须使用 bson
标记。 json
标签用于 encoding/json
包,Mongo 驱动程序不使用(忽略)它们。
type PlantData struct {
Minute int `bson:"minute"`
Date int `bson:"date"`
Moisture1 int `bson:"moisture_1"`
Hour int `bson:"hour"`
Month int `bson:"month"`
Year int `bson:"year"`
Humidity1 float64 `bson:"humidity_1"`
Temperature1 float64 `bson:"temperature_1"`
}
如果结构字段中缺少 bson
标签,MongoDB 中使用的默认名称将是以小写字母开头的结构字段名称,这就是某些(大多数)字段的原因匹配但不匹配 Moisture1
(它与 moisture_1
的区别不仅仅是首字母大写)。
如果您还想将 encoding/json
包与此结构一起使用,您可以同时提供:
type PlantData struct {
Minute int `bson:"minute" json:"minute"`
Date int `bson:"date" json:"date"`
Moisture1 int `bson:"moisture_1" json:"moisture_1"`
Hour int `bson:"hour" json:"hour"`
Month int `bson:"month" json:"month"`
Year int `bson:"year" json:"year"`
Humidity1 float64 `bson:"humidity_1" json:"humidity_1"`
Temperature1 float64 `bson:"temperature_1" json:"temperature_1"`
}