Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Conferences
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Learning Mongoid

You're reading from   Learning Mongoid If you know MongoDB and Ruby, then Mongoid is a very handy tool to have at your disposal. Quickly learn to build Rails applications with the helpful code samples and instructions in this book.

Arrow left icon
Product type Paperback
Published in Dec 2013
Publisher Packt
ISBN-13 9781782167501
Length 140 pages
Edition 1st Edition
Languages
Tools
Arrow right icon
Author (1):
Arrow left icon
Gautam Rege Gautam Rege
Author Profile Icon Gautam Rege
Gautam Rege
Arrow right icon
View More author details
Toc

The aggregation framework


The aggregation framework of MongoDB was introduced from MongoDB v2.0. It gives us similar functionality, such as the GROUP BY in SQL. This could be achieved easily by using MapReduce, but the aggregation is simpler!

Mongoid currently provides only the following basic aggregations: :count, :min, :max, :sum, and :avg.

So, to get a count of all the books use the following code:

irb> Book.count
=> 12

irb> Book.avg(:reviews_count)
 => 1.3333333333333333

The aggregation framework will be discussed in detail in the next chapter. In short, it uses an pipeline that streams output from one operation as the input of the next operation in the pipeline (similar to the | operator on the Unix shell). Though Mongoid supports the basic aggregations, we can also define our own complex aggregation pipelines. However, the aggregate method is not directly available on the models (as yet). Instead, we need to invoke it on the collection. Let's see an example that shows how...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image