簡體   English   中英

如何在nodejs的mongdb模式中計算數組object?

[英]how to count an array object in a mongdb schema in nodejs?

我想計算架構中的贊和評論的數量,這兩個都是 arrays。架構如下所示:

const PostSchema = new mongoose.Schema({
  text: {
    type: String,
    required: "Name is required",
  },

  photo: {
    data: Buffer,
    contentType: String,
  },
  likes: [{ type: mongoose.Schema.ObjectId, ref: "User" }],
  comments: [
    {
      text: String,
      created: { type: Date, default: Date.now },
      postedBy: { type: mongoose.Schema.ObjectId, ref: "User" },
      likes: Number,
    },
  ],
  postedBy: { type: mongoose.Schema.ObjectId, ref: "User" },
  created: {
    type: Date,
    default: Date.now,
  },
});

由於喜歡和評論都是 arrays 我想計算其中的元素數量並且我正在這樣做,我讀到了聚合 function 但無法弄清楚如何在這里使用它,因為我必須遍歷所有發布文件並獲取他們的喜歡和評論。

const leaderboard = (req, res) => {
  Post.find({}, function (err, docs) {
    docs.forEach(function (data) {
      var userid = data.postedBy;
      console.log(userid);
      var likes = data.likes.length;
      console.log(likes);
      var comments = data.comments.length;
      console.log(comments);
      const date2 = new Date();
      const diffTime = Math.abs(date2 - data.created);
      const diffDays = Math.ceil(diffTime / (1000 * 60 * 60 * 24));
      console.log(diffDays);
      const updated = User.findByIdAndUpdate(
        userid,
        {score: likes+comments+diffDays },
        function (errr, doc) {
          if (errr) {
            console.log(err);
          } else {
            console.log("Updated User : ", doc);
          }
        }
      );

我將非常感謝這里的幫助,謝謝!

您可以嘗試項目計數commentslikes的元素數量

Post.aggregate([
    {$project: {_id: 1, count: {$commentssize: '$comments'},count: {$sizelikes: '$likes'}}
])

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM