首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >按$size问题分类的流星集合

按$size问题分类的流星集合
EN

Stack Overflow用户
提问于 2016-06-03 11:08:49
回答 1查看 93关注 0票数 1

这是关于喜欢和不喜欢的评论。我想按相似程度对评论进行排序,所以首先会出现一个更喜欢的评论。问题是,与不喜欢的评论相比,不喜欢的评论出现在前面。

我想要的:

  • 评论A:1喜欢0不喜欢
  • 评论B:0喜欢0不喜欢
  • 评论C:0喜欢1不喜欢

我真正得到的是:

  • 评论A:1喜欢0不喜欢
  • 评论C:0喜欢1不喜欢
  • 评论B:0喜欢0不喜欢

我的蒙戈询问我的流星助手:

代码语言:javascript
复制
Missatges.find({ topic: 'xxx' }, { sort: { like:{ $size: -1}, dislike:{ $size: 1}, date: -1 } }).fetch();

请注意,我使用$size是因为and和are是user _id的数组。

代码语言:javascript
复制
author: {
    type: String

},
authorId: {
    type: SimpleSchema.RegEx.Id
}
isAnswer: {
    type: Boolean
},
parentId: {
    type: SimpleSchema.RegEx.Id,
    optional: true
},
date: {
    type: Date
},
topic: {
    type: String
},
likes: {
    type: [SimpleSchema.RegEx.Id]
},
dislikes: {
    type: [SimpleSchema.RegEx.Id]
},
answers: {
    type: [SimpleSchema.RegEx.Id],
    optional: true
},
text: {
    type: String,
    max: 900,        
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-03 12:27:02

根据this question的答案,您不能使用$size对mongo进行排序。一种解决方案是对匹配的文档进行fetch,并在帮助器中对它们进行sort。下面是一个示例(注意,这是未经测试的,可能需要进行一些调整):

代码语言:javascript
复制
Template.something.helpers({
  sortedThings: function () {
    return Missatges
      .find({ topic: 'xxx' })
      .fetch()
      .sort(function (b, a) {
        var al = a.likes.length;
        var ad = a.dislikes.length;
        var bl = a.likes.length;
        var bd = a.dislikes.length;
        var d1 = a.date;
        var d2 = b.date;

        // compare by likes
        if (al > bl) return 1;
        if (al < bl) return -1;

        // compare by dislikes
        if (ad < bd) return 1;
        if (ad > bd) return -1;

        // compare by date
        if (d1 > d2) return 1;
        if (d1 < d2) return -1;

        // they are equal
        return 0;
      });
  },
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37612799

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档