如何使用Golang在MongoDB中存储UUID?

问题描述

使用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