MongoDB Data Modeling

Han Yi

Know your business

Determine your position

2.Data Model

Logical Model

Physical Model

1.Domain Model

?

Master your kits

vs

Core concept: Data as a Document

Why Document ?

  • Humongous support
    • DoubleClick, 2007
    • 400000 ads/s
  • Flexible types for data model
    • Key-Value
    • List
    • Rich document
    • Embedded array and document
    • ...

Pros vs Cons of document model

  • Pros
    • ​Flexible data model design
    • High performance read
  • Cons
    • Design heavily depends on scenario
    • Single document should be no larger than 16mb, no deeper than 100 layers

Data model patterns for a document

  • Normalized
    • referenced in different document
  • Non-normalized
    • nested in single document
  • Tree structure
    • hybrid pattern

MongoDB prefer

  • Non-normalized

Real case

  • Fan Out Read
  • Fan Out Write

3 Factors of data modeling

  • Performance
  • Query pattern
  • Life cycle of data and growth rate of documents (Application domain)

Sample 1: Date modeling

  • BSON Date type is 64 bits signed number
  • BSON Date type is UTC time
  • Time zone is suggested using additional fields:

var now = new Date();

db.data.save( { date: now,

                            offset: now.getTimezoneOffset() } );

Sample 2: Monetary data modeling

  • Numeric Model
    • Decimal format (3.4+)
    • IEEE 754-2008: Decimal 128
    • Type long (64 bits) + Power factor (older than 3.4)
  • Non-numeric Model
    • Full value: String
    • Approximate value: double

Sample 3: Content query modeling

  • $regex
  • $text
  • Keywords array: multikey index

http://mongoing.com/

MongoDB Data Modeling

By hanyi8000

MongoDB Data Modeling

  • 2,041