我有mongodb数据库,其中每个集合中的每个文档都有_id字段,即.net GUID。现在我们想要使用java应用程序中的相同数据库。如何将GUID转换为UUID并正确映射对象?
答案 0 :(得分:1)
Java UUID和Mongodb UUID都实现了UUID standard。
可以用例如文本表示来解析文本表示。 fromString
:
UUID myUUID = UUID.fromString("449772DE-2780-4412-B9F7-E49E48605875");
要将UUID转换为字符串表示,请使用toString
:
String uuid = myUUID.toString();
// gives "449772de-2780-4412-b9f7-e49e48605875"
大写/小写无关紧要(在本例中可以看到)。
请参阅quickstart了解如何查询文档。
答案 1 :(得分:0)
我找到了解决方案。希望它会帮助别人。 所以我把用于CSUUID转换的util js文件的代码转换为robomongo中的UUID,并将其重写为JAVA。
private String HexToBase64(String hex) {
char[] base64Digits = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();
String base64 = "";
int group;
for (int i = 0; i < 30; i += 6) {
group = Integer.parseInt(mySubString(hex, i, 6), 16);
base64 += base64Digits[(group >> 18) & 0x3f];
base64 += base64Digits[(group >> 12) & 0x3f];
base64 += base64Digits[(group >> 6) & 0x3f];
base64 += base64Digits[group & 0x3f];
}
group = Integer.parseInt(mySubString(hex, 30, 2), 16);
base64 += base64Digits[(group >> 2) & 0x3f];
base64 += base64Digits[(group << 4) & 0x3f];
base64 += "==";
return base64;
}
private String mySubString(String myString, int start, int length) {
return myString.substring(start, Math.min(start + length, myString.length()));
}
private String CSUUID(String csuuid) {
String hex = csuuid.replaceAll("[{}-]", ""); // remove extra characters
String a = mySubString(hex, 6, 2) + mySubString(hex, 4, 2) + mySubString(hex, 2, 2) + mySubString(hex, 0, 2);
String b = mySubString(hex, 10, 2) + mySubString(hex, 8, 2);
String c = mySubString(hex, 14, 2) + mySubString(hex, 12, 2);
String d = mySubString(hex, 16, 16);
hex = a + b + c + d;
String base64 = HexToBase64(hex);
//return base64.getBytes(StandardCharsets.UTF_8);
return base64;
}
现在通过CSUUID执行查询需要执行这样的查询:
var user = _mongo.findOne(Query.query(Criteria.where("_id").is(new Binary(Bytes.B_UUID, Base64.getDecoder().decode(CSUUID(id.toString()))))), User.class);
谢谢!