Đối với điều này, hãy sử dụng MongoDB tổng hợp và trong đó, sử dụng $ cond. $ Cond đánh giá một biểu thức boolean để trả về một trong hai biểu thức trả về đã chỉ định.
Trước tiên, hãy để chúng tôi tạo một bộ sưu tập với các tài liệu -
> db.demo536.insertOne({"Name1":"Chris","Name2":"David"});{ "acknowledged" : true, "insertedId" : ObjectId("5e8c843eef4dcbee04fbbc01") } > db.demo536.insertOne({"Name1":"David","Name2":"Chris"});{ "acknowledged" : true, "insertedId" : ObjectId("5e8c843fef4dcbee04fbbc02") } > db.demo536.insertOne({"Name1":"Bob","Name2":"Sam"});{ "acknowledged" : true, "insertedId" : ObjectId("5e8c843fef4dcbee04fbbc03") } > db.demo536.insertOne({"Name1":"Chris","Name2":"David"});{ "acknowledged" : true, "insertedId" : ObjectId("5e8c843fef4dcbee04fbbc04") }
Hiển thị tất cả các tài liệu từ một bộ sưu tập với sự trợ giúp của phương thức find () -
> db.demo536.find();
Điều này sẽ tạo ra kết quả sau -
{ "_id" : ObjectId("5e8c843eef4dcbee04fbbc01"), "Name1" : "Chris", "Name2" : "David" } { "_id" : ObjectId("5e8c843fef4dcbee04fbbc02"), "Name1" : "David", "Name2" : "Chris" } { "_id" : ObjectId("5e8c843fef4dcbee04fbbc03"), "Name1" : "Bob", "Name2" : "Sam" } { "_id" : ObjectId("5e8c843fef4dcbee04fbbc04"), "Name1" : "Chris", "Name2" : "David" }
Sau đây là truy vấn để nhóm với nhiều trường -
> db.demo536.aggregate([ ... { ... $project: ... { ... FirstName1: ... { ... $cond: { if: { $gte: [ "$Name1", "$Name2" ] }, then: "$Name2", else: "$Name1" } ... }, ... FirstName2: ... { ... $cond: { if: { $lt: [ "$Name1", "$Name2" ] }, then: "$Name2", else: "$Name1" } ... } ... } ... } ... ,{ ... $group: ... { ... _id: ... { ... Name1: "$FirstName1", ... Name2: "$FirstName2" ... } ... ,count: { $sum: 1} ... } ... } ... ])
Điều này sẽ tạo ra kết quả sau &imnus;
{ "_id" : { "Name1" : "Bob", "Name2" : "Sam" }, "count" : 1 } { "_id" : { "Name1" : "Chris", "Name2" : "David" }, "count" : 3 }