如何在JAVA UUID中使用.net GUID作为mongodb集合的主键

时间:2017-10-11 10:11:10

标签: java mongodb maven spring-boot

我有mongodb数据库,其中每个集合中的每个文档都有_id字段,即.net GUID。现在我们想要使用java应用程序中的相同数据库。如何将GUID转换为UUID并正确映射对象?

2 个答案:

答案 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);  

谢谢!