0

我正在创建类似于新闻帖子的模式,用户可以选择喜欢和不喜欢它们。这是相同的模式

    Client= new mongoose.Schema({
        ip:String
    })

    Rates = new mongoose.Schema({
        client:ObjectId,
        newsid:ObjectId,
        rate:Number
    })

    News = new mongoose.Schema({
      title: String,
      body: String,
      likes:{type:Number,default:0},
      dislikes:{type:Number,default:0},
      created:Date,
      // tag:String,
      client:ObjectId,
      tag:String,
      ff:{type:Number,default:20}
    });

var newsm=mongoose.model('News', News);
var clientm=mongoose.model('Client', Client);
var ratesm=mongoose.model('Rates', Rates);

为了检索给定一组新闻帖子的特定用户给出的评级,我尝试了,

newsm.find({tag:tag[req.params.tag_id]},[],{ sort:{created:-1},limit: buffer+1 },function(err,news){    
   ratesm.find({
        client:client._id,
        newsid:{$lte:news[0]._id,$gte:news.slice(-1)[0]._id}
        },
        function(err,ratings){
    })
})

无论如何,此查询都会返回空列表。我怀疑 $gte 和 $lte 是否用于比较 objectIds。我对吗?我如何才能在给定的一组新闻帖子中喜欢/不喜欢哪些帖子?

4

1 回答 1

1

是的,可以使用 $gt/$lt 等范围查询来查询 ObjectIds。您可以发布所使用的确切值并且news[0]._idnews.slice(-1)[0]._id您空结果吗?

但是,我不确定 $gt/$lt 是你想要的。看起来您需要做的是提取_id新闻项目的 s,然后$in在您的查询中的过滤器中使用它ratesm

于 2012-05-18T15:39:11.467 回答