我有一个包含100条记录的MongoDB集合,在要检索10条记录的NodeJ中,每条包含10条记录,我该怎么做
答案 0 :(得分:1)
如果您希望记录是不同的,则可以使用Set对象来解决。该函数带有一个获取项密钥的函数,因此我们知道如何区分它们。
function groupByDistinct(records, groupSize, getKey) {
const set = new Set();
let result = [], current = [];
for (let i = 0, l = records.length; i < l; i++) {
const value = records[i], key = getKey(value);
if (set.has(key) {
continue;
}
set.add(key);
current.push(value);
if (current.length === groupSize) {
result.push(current);
current = [];
}
}
if (current.length !== 0) {
result.push(current);
}
return result;
}
示例用法
groupByDistinct(records, 10, x => x.key);