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
Learning Mongoid
Learning Mongoid

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.

eBook
€8.99 €19.99
Paperback
€24.99
Subscription
Free Trial
Renews at €18.99p/m

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing
Table of content icon View table of contents Preview book icon Preview Book

Learning Mongoid

Chapter 2. Mongoid Document Model

This is where we prepare to take the deep dive. In this chapter we shall see what we mean by documents and look into some of the internal access and storage. We shall learn about the various data types including some new ones that were added to Mongoid 3.

The Mongoid document


MongoDB stores documents that have fields and maybe other documents embedded in it. The documents are stored in collections. This is analogous to records stored in tables. The difference is that documents, unlike records in a SQL database, need not have the same structure or fields. In fact, as we have already seen in the previous chapter, there is no standard structure for storing documents in MongoDB.

So, do we define a default structure when we use Mongoid? Yes, not only can we define some basic default fields in a Mongoid document but we can also add fields dynamically (we saw this in the previous chapter). So we get the best of both worlds. If you have used ActiveRecord migrations earlier, remember that we don't need them anymore as we define the default fields in the model itself.

Documents are stored in the BSON format by MongoDB. BSON (Binary JSON) is a compact format that uses JSON standards for communication, and a serialized format for storage. This gives us...

Embedded documents


As the name suggests, documents embedded inside other documents are called embedded documents. When the parent document is fetched, it also fetches all the embedded documents. This is similar to the composition concept.

The following code shows how we can define an embedded document:

class Address
  include Mongoid::Document

  field :street, type: String
  field :city, type: String
  field :state, type: String
  field :zipcode, type: String
  field :country, type: String

  embedded_in :author
end

And the following code denotes how we can embed it into another model:

class Author
  include Mongoid::Document

  field :name, type: String
  
  has_many :books
  embeds_one :address
end

Now let's have a quick look at how this information was stored in the database. As it was an embedded document, when we fetched the author object, we also got the author's address.

> db.authors.findOne()
{
  "_id" : ObjectId("5143678345db7ca255000001"),
  "address" : {
    "_id" : ObjectId("514367f445db7ca255000003...

Localization


MongoDB inherently supports localization and in turn, so does Mongoid. MongoDB saves localized information in a hash. We can set a fallback to a default locale by setting an option in the Rails environment, that is, development.rb under config/environments as config.i18n.fallbacks = true. It's pretty straightforward. First let's configure a localized field.

class Book
  include Mongoid::Document

  #...
  field :currency, localize: true
end

Now we can play around with this localized field.

irb> b = Book.first
 => #<Book _id: 515c634c45db7c9233000001, t(title): nil, price: nil, page_count: nil, published_date: 2013-25-06 00:00:00 UTC, is_best_seller: false, awards: ["Booker Prize", "Pulitzer Prize"], reviews: nil, currency: nil, author_id: nil>
irb> I18n.locale
 => :en 
irb> b.currency = "GBP"
 => "GBP" 
irb> b.save
 => true 
irb> I18n.locale = :hi
 => :hi 
irb> b.currency = 'INR'
 => "INR" 
irb> b.save
 => true

Now if we fetch the...

Mass assignment and security


Mass assignment of attributes is a way in which we can assign multiple attributes of an object directly. Typically, the parameter hash params can be used directly to update the object. For example:

# params: { name: "Gautam", age: 35}
User.update_attributes(params)

But, what happens if someone updates information that should not have been part of params? What if someone inserted information such as password: "something" into the params hash? It will update the User object and create havoc.

That's exactly what happened.

Note

Early in 2012, Egor Homakov hacked github.com using this mass assignment Rails vulnerability. He was kind enough not to cause any harm and his intention was only to highlight the Rails' vulnerability of mass assignment.

He posted his own SSH key into the Rails core team user as a mass assignment, and it worked! He had full access to the repository after that. He highlighted that mass assignment is dangerous.

To protect against mass assignment, Rails...

Summary


In this chapter, we saw what Mongoid documents are and their various characteristics. We saw how various attributes such as arrays and hashes are stored. Using Mongoize and custom serialization, we can create new data types in Mongoid and use them in our models. We also saw things such as field aliasing, localization, and even mass assignment.

In the next chapter, we shall dig deep into Origin and see the various ways to persist data. We shall see various validations that are leveraged from ActiveModel, callbacks, and even atomic updates.

Left arrow icon Right arrow icon

Key benefits

  • A step-by-step guide that explains how to use Mongoid through lots of examples and code
  • Monitor and fine-tune the performance of your application
  • Work with the MongoDB aggregation framework

Description

Mongoid helps you to leverage the power of schema-less and efficient document-based design, dynamic queries, and atomic modifier operations. Mongoid eases the work of Ruby developers while they are working on complex frameworks. Starting with why and how you should use Mongoid, this book covers the various components of Mongoid. It then delves deeper into the detail of queries and relations, and you will learn some tips and tricks on improving performance. With this book, you will be able to build robust and large-scale web applications with Mongoid and Rails. Starting with the basics, this book introduces you to components such as moped and origin, and how information is managed, learn about the various datatypes, embedded documents, arrays, and hashes. You will learn how a document is stored and manipulated with callbacks, validations, and even atomic updates. This book will then show you the querying mechanism in detail, right from simple to complex queries, and even explains eager loading, lazy evaluation, and chaining of queries. Finally, this book will explain the importance of performance tuning and how to use the right indexes. It also explains MapReduce and the Aggregation Framework.

Who is this book for?

If you are an application developer who wants to learn how to use Mongoid in a Rails application, this book will be great for you. You are expected to be familiar with MongoDB and Ruby.

What you will learn

  • Learn the syntax of Mongoid 4 with Rails 4
  • Understand moped, the new Ruby driver for MongoDB Learn about document relations in Mongoid
  • Understand origin, the new querying DSL
  • Manage indexes in Mongoid
  • Learn about gems that work with Mongoid
  • Tune and monitor performance

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Dec 12, 2013
Length: 140 pages
Edition : 1st
Language : English
ISBN-13 : 9781782167501
Vendor :
MongoDB
Languages :
Tools :

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing

Product Details

Publication date : Dec 12, 2013
Length: 140 pages
Edition : 1st
Language : English
ISBN-13 : 9781782167501
Vendor :
MongoDB
Languages :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
€18.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
€189.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts
€264.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just €5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total 24.99
Learning Mongoid
€24.99
Total 24.99 Stars icon
Banner background image

Table of Contents

7 Chapters
What's so Awesome about Mongoid? Chevron down icon Chevron up icon
Mongoid Document Model Chevron down icon Chevron up icon
Persisting Documents Chevron down icon Chevron up icon
Mongoid Relations Chevron down icon Chevron up icon
Mongoid Queries Chevron down icon Chevron up icon
Performance Tuning Chevron down icon Chevron up icon
Mongoid Modules Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Half star icon 4.5
(2 Ratings)
5 star 50%
4 star 50%
3 star 0%
2 star 0%
1 star 0%
Maciej Mensfeld Feb 24, 2014
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Would I recommend this book? Yes! It can be a solid Mongo and Mongoid starting point for begginers and a “knowledge refresher” for people that use Mongoid longer that few weeks. It is well written and it has a lot of examples. Really a good one about Mongoid.It’s not extremely long - You may consider this an issue, but I’ve found this really helpful. Chapters aren’t long, so getting through them is not painful. Chapters (and the book itself) are really consistent. You won’t get bored reading this one or feel like giving up.This book is mostly about Mongoid. Don't expect Ruby/Rails/Gem management introduction or anything else. Even MongoDb performance/management stuff is not the subject of this study. On the other hand the book is called "Learning Mongoid" so everything extra is just a nice feature :-)As mentioned if it goes about learning Mongoid, this book does what it was meant to do.
Amazon Verified review Amazon
Stefan Frank Feb 19, 2014
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
This is a short, very focused book: It does exactly what it says: It shows you how to use mongoid - not more, but nothing less. When you pick up this short paper, you should already have your mind set on. You should not expect a lengthy introduction to rails or to mongodb, instead it jumps right to the point of connecting a rails-app to a mongoDB using mongoid.Although Mongoid‘s documentation has vastly improved in the last year or so, (which is probably one of the main reasons, barely anyone is using mongo-mapper anymore) – scrapping together decent examples for using it still takes some digging. So the book fills the – albeit small – gap between mongoid’s documentation and the myriad of tiny snippets you can dig up on stack-overflow. It is a small book, but it gives you examples on just about every piece of mongoid’ api along with helpful examples that show you how to use these api’s.The writing is clear and to the point, with helpful callouts pointing out common pitfalls&things you should look out for when using mongoid. Unlike other books of this nature, the examples do not lead to a complete application: instead, the examples are focused on demonstrating the specific part of the api and do a good job of showing you how to apply concept to a real-world(-ish) example.The bottom line:I liked it, that the book is short: it touches on every part of the api, giving you a good overview of mongoid: It is often very helpful when you already know that things like the paranoia-plugin exist and what their purpose is – when it comes to actually using is, you can still find the specifics online, now that you know what you are looking for.That being said, the shortness comes at a price:some topics come in a little too short:- There is probably more about scaling a mongoDB than just getting the formatting of your data-disk right(although it’s a start) – but then again, this is no book about mongodb. But maybe if you touch on the topic this light, you can leave it out altogether just as good…- the book shows every piece of the api, but it doesn’t help you much with choosing which pattern to use when. Mapping your domain onto a mongoid/mongodb model is not entirely straightforward and there are many ways you can model the same domain with different approaches – and this can be a bit challenging at first, especially when you come from a RDBMS-background. But again: This is not about modeling mongoDB-databases, this book is about mongoid-and-mongoid-only.-some examples are very terse and you can probably argue, that you can find these kind of examples on stack-overflow and combine it with the mongoid-docs (which are not soo bad to begin with): But having all this stuff together in one place is certainly helpful when you start.All in all, I liked the book: Even if you’ve been doing mongoid for some time, you will probably find the one or other thing in it you didn’t know yet about mongoid. And if you’re just starting with mongoid and you’re looking for a decent introduction to the whole api, this is certainly the book to go for.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is included in a Packt subscription? Chevron down icon Chevron up icon

A subscription provides you with full access to view all Packt and licnesed content online, this includes exclusive access to Early Access titles. Depending on the tier chosen you can also earn credits and discounts to use for owning content

How can I cancel my subscription? Chevron down icon Chevron up icon

To cancel your subscription with us simply go to the account page - found in the top right of the page or at https://subscription.packtpub.com/my-account/subscription - From here you will see the ‘cancel subscription’ button in the grey box with your subscription information in.

What are credits? Chevron down icon Chevron up icon

Credits can be earned from reading 40 section of any title within the payment cycle - a month starting from the day of subscription payment. You also earn a Credit every month if you subscribe to our annual or 18 month plans. Credits can be used to buy books DRM free, the same way that you would pay for a book. Your credits can be found in the subscription homepage - subscription.packtpub.com - clicking on ‘the my’ library dropdown and selecting ‘credits’.

What happens if an Early Access Course is cancelled? Chevron down icon Chevron up icon

Projects are rarely cancelled, but sometimes it's unavoidable. If an Early Access course is cancelled or excessively delayed, you can exchange your purchase for another course. For further details, please contact us here.

Where can I send feedback about an Early Access title? Chevron down icon Chevron up icon

If you have any feedback about the product you're reading, or Early Access in general, then please fill out a contact form here and we'll make sure the feedback gets to the right team. 

Can I download the code files for Early Access titles? Chevron down icon Chevron up icon

We try to ensure that all books in Early Access have code available to use, download, and fork on GitHub. This helps us be more agile in the development of the book, and helps keep the often changing code base of new versions and new technologies as up to date as possible. Unfortunately, however, there will be rare cases when it is not possible for us to have downloadable code samples available until publication.

When we publish the book, the code files will also be available to download from the Packt website.

How accurate is the publication date? Chevron down icon Chevron up icon

The publication date is as accurate as we can be at any point in the project. Unfortunately, delays can happen. Often those delays are out of our control, such as changes to the technology code base or delays in the tech release. We do our best to give you an accurate estimate of the publication date at any given time, and as more chapters are delivered, the more accurate the delivery date will become.

How will I know when new chapters are ready? Chevron down icon Chevron up icon

We'll let you know every time there has been an update to a course that you've bought in Early Access. You'll get an email to let you know there has been a new chapter, or a change to a previous chapter. The new chapters are automatically added to your account, so you can also check back there any time you're ready and download or read them online.

I am a Packt subscriber, do I get Early Access? Chevron down icon Chevron up icon

Yes, all Early Access content is fully available through your subscription. You will need to have a paid for or active trial subscription in order to access all titles.

How is Early Access delivered? Chevron down icon Chevron up icon

Early Access is currently only available as a PDF or through our online reader. As we make changes or add new chapters, the files in your Packt account will be updated so you can download them again or view them online immediately.

How do I buy Early Access content? Chevron down icon Chevron up icon

Early Access is a way of us getting our content to you quicker, but the method of buying the Early Access course is still the same. Just find the course you want to buy, go through the check-out steps, and you’ll get a confirmation email from us with information and a link to the relevant Early Access courses.

What is Early Access? Chevron down icon Chevron up icon

Keeping up to date with the latest technology is difficult; new versions, new frameworks, new techniques. This feature gives you a head-start to our content, as it's being created. With Early Access you'll receive each chapter as it's written, and get regular updates throughout the product's development, as well as the final course as soon as it's ready.We created Early Access as a means of giving you the information you need, as soon as it's available. As we go through the process of developing a course, 99% of it can be ready but we can't publish until that last 1% falls in to place. Early Access helps to unlock the potential of our content early, to help you start your learning when you need it most. You not only get access to every chapter as it's delivered, edited, and updated, but you'll also get the finalized, DRM-free product to download in any format you want when it's published. As a member of Packt, you'll also be eligible for our exclusive offers, including a free course every day, and discounts on new and popular titles.