如何在Mongoose中组合两个集合并使用createdDate对它们进行排序

时间:2015-05-30 17:14:02

标签: angularjs node.js mongodb mongoose

我正在使用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
        });

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

1 个答案:

答案 0 :(得分:1)

Mongodb本身不是关系数据库,任何类型的“连接”操作都是不可能的。我认为有两种方法:

  1. 简单方法,但不是最好的方法: 例如,如果您需要在页面上显示30个项目,则需要:
    • 从铃声加载30个项目,从AlbumSchema
    • 加载30个项目
    • 将它们放在一个数组中
    • 在记忆中做最后的排序。
  2. 此方法的缺点是您需要将更多数据加载到内存中而不是需要,并且还需要手动执行内存排序。

    1. 更好的方法。如果您需要显示来自两个集合的数据,那么如果有两个集合则可以是一个好的标志。您的两个集合架构看起来非常相似。稍后,您可以使用sparse indexes来优化仅需要两个实体之一的查询。
    2. 如果您选择第一种方式的实施细节:您可以使用async或使用promises并行加载来自两个查询的数据,并使用underscore

      进行最终内存排序

      希望这有帮助!