| | SELECT COUNT(*) AS count |  | FROM orders | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: null, |  | count: { $sum: 1 } |  | } |  | } |  | ] ) | 
 | Count all records
from orders | 
| | SELECT SUM(price) AS total |  | FROM orders | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: null, |  | total: { $sum: "$price" } |  | } |  | } |  | ] ) | 
 | Sum the pricefield
fromorders | 
| | SELECT cust_id, |  | SUM(price) AS total |  | FROM orders |  | GROUP BY cust_id | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: "$cust_id", |  | total: { $sum: "$price" } |  | } |  | } |  | ] ) | 
 | For each unique cust_id,
sum thepricefield. | 
| | SELECT cust_id, |  | SUM(price) AS total |  | FROM orders |  | GROUP BY cust_id |  | ORDER BY total | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: "$cust_id", |  | total: { $sum: "$price" } |  | } |  | }, |  | { $sort: { total: 1 } } |  | ] ) | 
 | For each unique cust_id,
sum thepricefield,
results sorted by sum. | 
| | SELECT cust_id, |  | ord_date, |  | SUM(price) AS total |  | FROM orders |  | GROUP BY cust_id, |  | ord_date | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: { |  | cust_id: "$cust_id", |  | ord_date: { $dateToString: { |  | format: "%Y-%m-%d", |  | date: "$ord_date" |  | }} |  | }, |  | total: { $sum: "$price" } |  | } |  | } |  | ] ) | 
 | For each unique
cust_id,ord_dategrouping,
sum thepricefield.
Excludes the time portion of the date. | 
| | SELECT cust_id, |  | count(*) |  | FROM orders |  | GROUP BY cust_id |  | HAVING count(*) > 1 | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: "$cust_id", |  | count: { $sum: 1 } |  | } |  | }, |  | { $match: { count: { $gt: 1 } } } |  | ] ) | 
 | For cust_idwith multiple records,
return thecust_idand
the corresponding record count. | 
| | SELECT cust_id, |  | ord_date, |  | SUM(price) AS total |  | FROM orders |  | GROUP BY cust_id, |  | ord_date |  | HAVING total > 250 | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: { |  | cust_id: "$cust_id", |  | ord_date: { $dateToString: { |  | format: "%Y-%m-%d", |  | date: "$ord_date" |  | }} |  | }, |  | total: { $sum: "$price" } |  | } |  | }, |  | { $match: { total: { $gt: 250 } } } |  | ] ) | 
 | For each unique cust_id,ord_dategrouping, sum thepricefield
and return only where the
sum is greater than 250.
Excludes the time portion of the date. | 
| | SELECT cust_id, |  | SUM(price) as total |  | FROM orders |  | WHERE status = 'A' |  | GROUP BY cust_id | 
 | | db.orders.aggregate( [ |  | { $match: { status: 'A' } }, |  | { |  | $group: { |  | _id: "$cust_id", |  | total: { $sum: "$price" } |  | } |  | } |  | ] ) | 
 | For each unique cust_idwith statusA,
sum thepricefield. | 
| | SELECT cust_id, |  | SUM(price) as total |  | FROM orders |  | WHERE status = 'A' |  | GROUP BY cust_id |  | HAVING total > 250 | 
 | | db.orders.aggregate( [ |  | { $match: { status: 'A' } }, |  | { |  | $group: { |  | _id: "$cust_id", |  | total: { $sum: "$price" } |  | } |  | }, |  | { $match: { total: { $gt: 250 } } } |  | ] ) | 
 | For each unique cust_idwith statusA,
sum thepricefield and return
only where the
sum is greater than 250. | 
| | SELECT cust_id, |  | SUM(li.qty) as qty |  | FROM orders o, |  | order_lineitem li |  | WHERE li.order_id = o.id |  | GROUP BY cust_id | 
 | | db.orders.aggregate( [ |  | { $unwind: "$items" }, |  | { |  | $group: { |  | _id: "$cust_id", |  | qty: { $sum: "$items.qty" } |  | } |  | } |  | ] ) | 
 | For each unique cust_id,
sum the corresponding
line itemqtyfields
associated with the
orders. | 
| | SELECT COUNT(*) |  | FROM (SELECT cust_id, |  | ord_date |  | FROM orders |  | GROUP BY cust_id, |  | ord_date) |  | as DerivedTable | 
 | | db.orders.aggregate( [ |  | { |  | $group: { |  | _id: { |  | cust_id: "$cust_id", |  | ord_date: { $dateToString: { |  | format: "%Y-%m-%d", |  | date: "$ord_date" |  | }} |  | } |  | } |  | }, |  | { |  | $group: { |  | _id: null, |  | count: { $sum: 1 } |  | } |  | } |  | ] ) | 
 | Count the number of distinct
cust_id,ord_dategroupings.
Excludes the time portion of the date. |