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==")。
您可以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 一起工作。
| 归档时间: |
|
| 查看次数: |
3294 次 |
| 最近记录: |