【问题标题】:How to combine two collections in Mongoose and sort them using createdDate如何在 Mongoose 中组合两个集合并使用 createdDate 对它们进行排序
【发布时间】:2015-05-31 02:23:17
【问题描述】:

我正在使用 MEAN.js 开发应用程序,其中有两个文档如下:

 var RingtoneSchema = new Schema({
      language: {
            label: String,
            code : String
        },
        deliver:{
            type:Boolean,
            default:false
        },
        artists: [RingtoneArtist],
        digital_booklet:{
           title: {
              type: String,
              trim:true

           },
          copyright:{
              type: String,
              trim:true

          }
        }
        title: {
            type: String,
            default: '',
            required: 'Please fill Album title',
            trim: true
        },
        created: {
            type: Date,
            default: Date.now
        }
    });


    var AlbumSchema = new Schema({
      language: {
            label: String,
            code : String
        },
        deliver:{
            type:Boolean,
            default:false
        },
        artists: [artist],
        title: {
            type: String,
            default: '',
            required: 'Please fill Album title',
            trim: true
        },
    created: {
            type: Date,
            default: Date.now
        });

我想从两个模式中获取所有记录并按创建日期对它们进行排序以在客户端显示它们。我不知道如何使用猫鼬来做到这一点。 任何帮助将不胜感激。

【问题讨论】:

    标签: angularjs node.js mongodb mongoose


    【解决方案1】:

    Mongodb 本身不是关系数据库,任何类型的“join”操作都是不可能的。我看到了两种方法:

    1. 简单的方法,但不是最好的方法: 例如,如果您需要在一个页面上显示 30 个项目,您需要:
      • 从铃声加载 30 项,从 AlbumSchema 加载 30 项
      • 将它们放在一个数组中
      • 在内存中进行最终排序。

    这种方法的缺点是您需要将比需要更多的数据加载到内存中,并且还需要手动执行内存排序。

    1. 更好的方法。如果您需要显示来自两个集合的数据,那么拥有一个集合而不是两个集合可能是一个好兆头。您的两个集合架构看起来非常相似。稍后您可以使用sparse indexes 来优化只需要两个实体之一的查询。

    如果您选择第一种方式,实现细节:您可以使用 async 或使用 promises 从两个并行查询中加载数据,并使用 underscore 在内存中进行最终排序

    希望这会有所帮助!

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2023-03-18
      • 2022-10-04
      • 2016-09-23
      • 1970-01-01
      • 2020-08-09
      • 1970-01-01
      • 1970-01-01
      • 2023-03-12
      相关资源
      最近更新 更多