AzureCosmoDB+Azurefunctions的$sample聚合返回的结果不是预期的随机结果。
创始人
2024-09-29 14:00:37
0

问题很可能是由于CosmoDB分区键导致的。如果使用具有分区键的集合,$sample聚合操作可能会在同一分区中返回相同结果。要解决这个问题,可以使用无分区键的集合。若要使用带有分区键的集合,请将sample聚合操作与分区键组合使用,如以下示例代码所示:

module.exports = async function (context, req) {
    const { MongoClient } = require('mongodb');
    const [requiredEnv, databaseName] = ['MONGODB_CONNECTION_STR', 'your_database_name'];
    const partitionKey = 'your_partition_key';
    const collectionName = 'sample_collection';
    const size = 3;
    const client = new MongoClient(process.env[requiredEnv], { useNewUrlParser: true, useUnifiedTopology: true });
    await client.connect();
    const database = client.db(databaseName);
    const collection = database.collection(collectionName);
    const querySpec = {
        'query': `SELECT TOP 1 * FROM Root r WHERE r.${partitionKey} = @partitionKey ORDER BY 
        r._ts DESC`,
        'parameters': [
            {
                'name': '@partitionKey',
                'value': 'your_partition_value'
            }
        ]
    };
    const result = collection.aggregate([{ $match: { partitionKey: "your_partition_value" } }, { $sample: { size: size } }]);
    context.res = {
        body: result
    };
};

在上面的代码示例中,sample操作与查询语句组合使用,以便在同一分区中返回随机结果。

相关内容

热门资讯

透视规律!德普之星私人局辅助器... 透视规律!德普之星私人局辅助器(透视)德普之星app安卓版破解版-确实有挂(哔哩哔哩)德普之星app...
透视线上!aapoker公共底... 透视线上!aapoker公共底牌(透视)hhpoker是正品吗-切实是真的挂(哔哩哔哩)1、首先打开...
连日来!hhpoker万能辅助... 连日来!hhpoker万能辅助器(透视)德州局hhpoker-竟然是有挂(哔哩哔哩)1、hhpoke...
经调查!aapoker怎么设置... 经调查!aapoker怎么设置提高好牌几率(透视)hhpoker有辅助吗-一贯存在有挂(哔哩哔哩)a...
透视辅助!hhpoker透视码... 透视辅助!hhpoker透视码(透视)hhpoker辅助靠谱吗-原来真的有挂(哔哩哔哩)1、金币登录...
透视线上!德州局hhpoker... 透视线上!德州局hhpoker(透视)hhpoker真的有透视吗-确实真的是有挂(哔哩哔哩)1、用户...
透视模拟器!werplan辅助... 透视模拟器!werplan辅助软件(透视)佛手在线是不是有挂-果然是真的挂(哔哩哔哩)1、在佛手在线...
最终!aa poker辅助包(... 最终!aa poker辅助包(透视)xpoker辅助怎么用-都是存在有挂(哔哩哔哩)1、进入游戏-大...
黑科技辅助挂!aapoker怎... 黑科技辅助挂!aapoker怎么控制牌(透视)德州局hhpoker-竟然是真的挂(哔哩哔哩)1、进入...
据通报!wepoker养号规律... 据通报!wepoker养号规律(透视)wepoker私人局可以透视-一贯有挂(哔哩哔哩)1、wepo...