Mongo UUID 类型 03 而不是来自 mongo shell 的 04

dil*_*ngi 3 mongodb mongo-shell mongodb-query

来自 Mongo Shell 的 MongoDB UUID 转换结果是 TYPE 03,旧格式。我们如何让它与 TYPE 04 二进制格式一起工作?

> db.foo.insert({"_id":1000,"key1":UUID("240003A09CEC456AB57B98FF8E0E45DB")})
  WriteResult({ "nInserted" : 1 })
> db.foo.find({_id:1000})
  { "_id" : 1000, "key1" : BinData(3,"JAADoJzsRWq1e5j/jg5F2w==") }
> db.version()
  3.4.2
Run Code Online (Sandbox Code Playgroud)

从 Java 代码中,我们可以使用字节缓冲区并作为类型 04 的二进制 uuid 插入,示例:BinData(4,"XWCwWqIVTfiEkTx9Yl+2UQ==")。

Nei*_*unn 6

您可以BinData()通过提取 base64 编码并提供它,将数据作为类型 4直接放入函数中:

var t = BinData(4, UUID("240003a09cec456ab57b98ff8e0e45db").base64())
BinData(4,"JAADoJzsRWq1e5j/jg5F2w==")
Run Code Online (Sandbox Code Playgroud)

然后你仍然从十六进制获得提供的值:

t.hex()
240003a09cec456ab57b98ff8e0e45db
Run Code Online (Sandbox Code Playgroud)

或者直接供应给HexData()

HexData(4,"240003a09cec456ab57b98ff8e0e45db")
BinData(4,"JAADoJzsRWq1e5j/jg5F2w==")
Run Code Online (Sandbox Code Playgroud)

如果您的数据中间有连字符,请使用.split().join()重新格式化:

var str =  "240003A0-9CEC-456A-b57B-98FF8e0E45DB";
str.split('-').join("").toLowerCase();
"240003a09cec456ab57b98ff8e0e45db"
Run Code Online (Sandbox Code Playgroud)

存在 JIRA 票证以使UUID()生成类型 4 作为默认SERVER-12835,但这是一个低优先级问题。对于一般用途,您的交互应该基于“驱动程序”。但是有这些方法可以与 shell 一起工作。