MongoDB
 sql >> Cơ Sở Dữ Liệu >  >> NoSQL >> MongoDB

Nhận phần trăm với MongoDB tổng hợp $ nhóm

Tôi nghĩ là percentage phải là chuỗi nếu giá trị chứa %

Trước tiên, bạn sẽ cần phải count số lượng tài liệu.

var nums = db.collection.count();

db.collection.aggregate(
    [
        { "$group": { "_id": {"type":  "$type"}, "count": { "$sum": 1 }}},    
        { "$project": { 
            "count": 1, 
            "percentage": { 
                "$concat": [ { "$substr": [ { "$multiply": [ { "$divide": [ "$count", {"$literal": nums }] }, 100 ] }, 0,2 ] }, "", "%" ]}
            }
        }
    ]
)

Kết quả

{ "_id" : { "type" : "short" }, "count" : 3, "percentage" : "60%" }
{ "_id" : { "type" : "big" }, "count" : 2, "percentage" : "40%" }


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB $ toBool

  2. Chỉ mục trong MongoDB

  3. Chức năng Azure với tích hợp Cosmos MongoDB không lưu

  4. Hướng dẫn triển khai và bảo trì MongoDB bằng Puppet:Phần 2

  5. Lưu trữ mật khẩu với Node.js và MongoDB