是否有内置函数可以跨所有记录获取数组字段中的所有唯一值?

Posted

技术标签:

【中文标题】是否有内置函数可以跨所有记录获取数组字段中的所有唯一值?【英文标题】:Is there a built-in function to get all unique values in an array field, across all records? 【发布时间】:2015-08-31 12:11:17 【问题描述】:

我的架构如下所示:

var ArticleSchema = new Schema(
...
  category: [
    type: String,
    default: ['general']
  ],
...
);

我想解析所有记录并在所有记录中找到该字段的所有唯一值。这将通过被服务调用发送到前端,以对标记文章进行前瞻搜索。

我们可以遍历每条记录并遍历每个数组值并进行检查,但这将是 O(n2)。

是否有现有的功能或其他方式具有更好的性能?

【问题讨论】:

【参考方案1】:

您可以使用distinct 函数获取所有文档的所有category 数组字段的唯一值:

Article.distinct('category', function(err, categories) 
    // categories is an array of the unique category values
);

category 上建立索引以获得最佳性能。

【讨论】:

以上是关于是否有内置函数可以跨所有记录获取数组字段中的所有唯一值?的主要内容,如果未能解决你的问题,请参考以下文章

Mongodb检查数组的子文档中是否存在字段

防止在 Swift 中使用 .childAdded 从 Firebase 获取所有数据

是否有一种内置方法可以从 PHP 中的多暗淡数组中获取数组?

将所有mysql选定的行放入一个数组中

查找数组字段不为空的 MongoDB 记录

查找数组字段不为空的 MongoDB 记录