NULLを無視するMongoDB集約の条件付き$first?
アグリゲート()の下で$ match演算子を使用して、最初のレコードを取得できます。まず、ドキュメントを使用してコレクションを作成しましょう-
> db.conditionalFirstDemo.insertOne({_id:100,"StudentName":"Chris","StudentSubject":null}); { "acknowledged" : true, "insertedId" : 100 } > db.conditionalFirstDemo.insertOne({_id:101,"StudentName":"Chris","StudentSubject":null}); { "acknowledged" : true, "insertedId" : 101 } >db.conditionalFirstDemo.insertOne({_id:102,"StudentName":"Chris","StudentSubject":"MongoDB"}); { "acknowledged" : true, "insertedId" : 102 } >db.conditionalFirstDemo.insertOne({_id:103,"StudentName":"Chris","StudentSubject":"MongoDB"}); { "acknowledged" : true, "insertedId" : 103 } > db.conditionalFirstDemo.insertOne({_id:104,"StudentName":"Chris","StudentSubject":null}); { "acknowledged" : true, "insertedId" : 104 }
以下は、find()メソッドを使用してコレクションからすべてのドキュメントを表示するためのクエリです-
> db.conditionalFirstDemo.find();
これにより、次の出力が生成されます-
{ "_id" : 100, "StudentName" : "Chris", "StudentSubject" : null } { "_id" : 101, "StudentName" : "Chris", "StudentSubject" : null } { "_id" : 102, "StudentName" : "Chris", "StudentSubject" : "MongoDB" } { "_id" : 103, "StudentName" : "Chris", "StudentSubject" : "MongoDB" } { "_id" : 104, "StudentName" : "Chris", "StudentSubject" : null }
以下は、MongoDBアグリゲーションの条件付き$firstへのクエリです-
> db.conditionalFirstDemo.aggregate([ { "$match": { "StudentSubject": { "$ne": null } } }, { "$group": { "_id": "$StudentName", "StudentSubject": { "$first": "$StudentSubject" } }} ]);
これにより、次の出力が生成されます-
{ "_id" : "Chris", "StudentSubject" : "MongoDB" }
-
MongoDBはnullではないかどうかをチェックしていますか?
$ neを使用して、nullでないことを確認します。ドキュメントを使用してコレクションを作成しましょう- > db.demo764.insertOne({"LoginUserName":"Chris","LoginPassword":"Chris_12"}); { "acknowledged" : true, "insertedId" : ObjectId("5eb04ee55637cd592b2a4afc&
-
MongoDBの集約と投影?
このために、aggregate()と一緒に$projectを使用します。集約された$projectは、要求されたフィールドを持つドキュメントをパイプラインの次のステージに渡します。 ドキュメントを使用してコレクションを作成しましょう- > db.demo762.insertOne({ ... "_id" : { ... "userId":101, ... "userName":"Chris" ...