问题描述
使用Golang在MongoDB中存储github.com/google/uuid
UUID字段时,它会转换为子类型为0的base64二进制文件。这使得无法通过UUID自然查询文档字段。
插入的用户如下:
{"_id":{"$binary":"0bHYoNWSTV+KqWSl54YWiQ==","$type":"0"},"name":"Isabella"}
通过生成的UUID d1b1d8a0-d592-4d5f-8aa9-64a5e7861689
查询时,结果为空。
type User struct {
UserId uuid.UUID `json:"userId" bson:"_id"`
Name string `json:"name" bson:"name"`
}
func (repo userRepo) User(uuidIn uuid.UUID) (model.User,error) {
collection := repo.database.Collection(mongoCollectionUser)
var user model.User
err := collection.FindOne(context.Background(),bson.M{"_id": uuidIn},).Decode(&user)
// err: mongo: no documents in result
}
解决方法
由于github.com/google/uuid
UUID类型是[16]byte
的别名,Mongo将求助于将其存储为子类型0x00的BSON二进制文件。尝试将UUID转换为BSON的base64二进制格式是不切实际的。因此,您可以选择使用我编写的此编码器和解码器功能,可以直接将其插入mongo客户端结构中:https://gist.github.com/SupaHam/3afe982dc75039356723600ccc91ff77