MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

MongoDB — głosowanie za komentarzami/głosowanie przeciw za pomocą potoku agregacji

możesz to zrobić za pomocą następującej aktualizacji potoku, ale wymaga to istnienia tablic upvotes i downvotes. nawet jeśli jest po prostu pusty.

var comment_id = ObjectId("5e5983102328a83d1a4b541f");
var user_id = ObjectId("5e5983102328a83d1a4b53e5");

db.commentReputation.update(
    {
        commentId: comment_id
    },
    [
        {
            $set: {
                upvotes: {
                    $cond: [
                        { $in: [user_id, '$upvotes'] },
                        { $setDifference: ['$upvotes', [user_id]] },
                        { $setUnion: ['$upvotes', [user_id]] }
                    ]
                }
            }
        },
        {
            $set: {
                downvotes: {
                    $cond: [
                        { $in: [user_id, '$downvotes'] },
                        { $setDifference: ['$downvotes', [user_id]] },
                        '$downvotes'
                    ]
                }
            }
        }
    ]
);



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. db.collection nie jest funkcją podczas korzystania z MongoClient v3.0

  2. Lepszy sposób na przeniesienie kolekcji MongoDB do innej kolekcji

  3. Nie można połączyć się z lokalnym (działającym) mongo za pomocą „meteor mongo”

  4. Jak wykonać agregację w mongodb w frameworku laravel

  5. wielokrotny operator aktualizacji mongo w jednym oświadczeniu?