我正在使用类似这样的结构
type User struct {
Username string `json: "username" bson: "username"`
FirstName string `json: "firstName" bson: "firstName"`
LastName string `json: "lastName" bson: "lastName"`
Email string `json: "email" bson: "email"`
Gender string `json: "gender" bson: "gender"`
Password string `json: "password" bson: "password"`
Enabled bool `json: "enabled" bson: "enabled"`
BirthDate time.Time `json: "birthDate" bson: "birthDate"`
CreatedAt time.Time `json: "createdAt" bson: "createdAt"`
UpdatedAt time.Time `json: "updatedAt" bson: "updatedAt"`
collection *mongo.Collection
}
然后使用
查询数据func (u *User) FindByUsername(userName string) error {
var ctx, _ = context.WithTimeout(context.Background(), 10*time.Second)
filter := bson.M{"username": userName}
err := u.collection.FindOne(ctx, filter).Decode(&u)
return err
}
我得到的结果是
{"Username":"jbond","FirstName":"","LastName":"","Email":"email@gmail.com","Gender":"Male","Password":"","Enabled":true,"BirthDate":"0001-01-01T00:00:00Z","CreatedAt":"0001-01-01T00:00:00Z","UpdatedAt":"0001-01-01T00:00:00Z"}
除了驼峰式字段外,大多数数据都已填充,当我从控制台查询时,数据就在那里
> db.users.find().pretty()
{
"_id" : ObjectId("xxxxxxxxxxxxxxxxxxxxxxxx"),
"username" : "jbond",
"firstName" : "James",
"lastName" : "Bond",
"email" : "email@gmail.com",
"password" : "",
"enabled" : true,
"gender" : "Male",
"birthDate" : {
"type" : {
"code" : "function Date() {\n [native code]\n}"
}
},
"createdAt" : {
"type" : {
"code" : "function Date() {\n [native code]\n}"
},
"default" : {
"code" : "function now() {\n [native code]\n}"
}
},
"updatedAt" : {
"type" : {
"code" : "function Date() {\n [native code]\n}"
},
"default" : {
"code" : "function now() {\n [native code]\n}"
}
}
}
我不明白为什么都应该小写。还是我错过了什么?
答案 0 :(得分:3)
否,它不会对驼峰式字段进行解码。无法解析struct标记。
根据doc:
按照惯例,标记字符串是由可选的以空格分隔的键:“值”对的串联。每个键都是一个非空字符串,由非控制字符组成,除了空格(U + 0020''),引号(U + 0022'“')和冒号(U + 003A':')。每个值都用引号引起来使用U + 0022'“'字符和Go字符串文字语法。
您应删除json:
和bson:
之后的空格。