Mongo Shell将字符串转换为nuuid并进行比较

时间:2018-09-05 14:41:35

标签: mongodb mongo-shell

我想执行以下操作:


    db
    .getCollection('COLLECTION')
    .find({ $where : function() { return NUUID(this.Col1) != this.Col2 }})

其中Col1包含NUUID字符串,而Col2包含NUUID。

我想要Col1(是字符串)的NUUID值不等于Col2的行。

我收到错误:ReferenceError: NUUID is not defined

1 个答案:

答案 0 :(得分:0)

使用https://github.com/mongodb/mongo-csharp-driver/blob/master/uuidhelpers.js,解决方案是:

db
.getCollection('TestColl')
.find({$where: function(){

    function CSUUID(uuid) {
        var hex = uuid.replace(/[{}-]/g, ""); // remove extra characters
        var a = hex.substr(6, 2) + hex.substr(4, 2) + hex.substr(2, 2) + hex.substr(0, 2);
        var b = hex.substr(10, 2) + hex.substr(8, 2);
        var c = hex.substr(14, 2) + hex.substr(12, 2);
        var d = hex.substr(16, 16);
        hex = a + b + c + d;
        var base64 = HexToBase64(hex);
        return new BinData(3, base64);
    }

    function HexToBase64(hex) {
        var base64Digits = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
        var base64 = "";
        var group;
        for (var i = 0; i < 30; i += 6) {
            group = parseInt(hex.substr(i, 6), 16);
            base64 += base64Digits[(group >> 18) & 0x3f];
            base64 += base64Digits[(group >> 12) & 0x3f];
            base64 += base64Digits[(group >> 6) & 0x3f];
            base64 += base64Digits[group & 0x3f];
        }
        group = parseInt(hex.substr(30, 2), 16);
        base64 += base64Digits[(group >> 2) & 0x3f];
        base64 += base64Digits[(group << 4) & 0x3f];
        base64 += "==";
        return base64;
    }

    return CSUUID(this['Col1']).toString() != this['Col2'].toString()

    }
})