Bird
Raised Fist0
MongoDBquery~10 mins

ObjectId and how it is generated in MongoDB - Step-by-Step Execution

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Concept Flow - ObjectId and how it is generated
Start: Need unique ID
Generate Timestamp (4 bytes)
Generate Machine ID (3 bytes)
Generate Process ID (2 bytes)
Generate Counter (3 bytes)
Combine all parts into 12-byte ObjectId
Use ObjectId as unique document ID
ObjectId is created by combining time, machine, process, and counter parts to make a unique 12-byte ID.
Execution Sample
MongoDB
ObjectId() // generates a new unique 12-byte ID
This code creates a new ObjectId by combining timestamp, machine ID, process ID, and counter.
Execution Table
StepPart GeneratedValue (Hex)Description
1Timestamp64E3A2F4Current time in seconds since epoch (4 bytes)
2Machine ID5F1D3AUnique machine identifier (3 bytes)
3Process ID1A2BCurrent process identifier (2 bytes)
4Counter000001Incrementing counter to avoid duplicates (3 bytes)
5Combine64E3A2F45F1D3A1A2B000001Final 12-byte ObjectId
💡 All parts combined to form a unique ObjectId for document identification
Variable Tracker
PartInitialAfter GenerationFinal
TimestampN/A64E3A2F464E3A2F4
Machine IDN/A5F1D3A5F1D3A
Process IDN/A1A2B1A2B
Counter011
ObjectIdN/AN/A64E3A2F45F1D3A1A2B000001
Key Moments - 3 Insights
Why does ObjectId include a timestamp?
The timestamp (step 1 in execution_table) ensures ObjectIds are roughly ordered by creation time and helps uniqueness.
What prevents two ObjectIds from being the same on the same machine and process?
The counter (step 4) increments for each ObjectId generated in the same second, avoiding duplicates.
Why is the machine ID part important?
The machine ID (step 2) ensures ObjectIds generated on different machines are unique even if timestamp and counter match.
Visual Quiz - 3 Questions
Test your understanding
Look at the execution_table, what is the length in bytes of the Process ID part?
A3 bytes
B2 bytes
C4 bytes
D1 byte
💡 Hint
Check the 'Part Generated' and 'Value (Hex)' columns in the execution_table for Process ID
At which step is the counter value generated?
AStep 4
BStep 3
CStep 1
DStep 5
💡 Hint
Look for the row where 'Counter' is generated in the execution_table
If the machine ID was the same but the process ID changed, what would happen to the ObjectId?
AIt would be the same
BOnly the timestamp changes
CIt would be completely different
DOnly the counter changes
💡 Hint
Refer to how ObjectId combines machine ID and process ID in the execution_table
Concept Snapshot
ObjectId is a 12-byte unique ID.
It combines 4 parts: timestamp (4 bytes), machine ID (3 bytes), process ID (2 bytes), and counter (3 bytes).
Timestamp orders IDs by creation time.
Machine and process IDs ensure uniqueness across machines and processes.
Counter avoids duplicates within the same second.
Full Transcript
ObjectId in MongoDB is a unique identifier for documents. It is 12 bytes long and made by combining four parts: a 4-byte timestamp representing the current time, a 3-byte machine identifier unique to the computer, a 2-byte process ID for the running program, and a 3-byte counter that increments with each new ObjectId. This combination ensures each ObjectId is unique and roughly ordered by creation time. The timestamp helps sort documents by creation time. The machine and process IDs prevent collisions across different servers and processes. The counter prevents duplicates when multiple ObjectIds are created quickly on the same machine and process. This process creates a unique 12-byte hexadecimal string used as the document's ID.

Practice

(1/5)
1. What does a MongoDB ObjectId primarily represent?
easy
A. A random number generated by the client
B. A unique identifier for documents in a collection
C. A user's login session ID
D. A timestamp of when the database was created

Solution

  1. Step 1: Understand the purpose of ObjectId

    ObjectId is designed to uniquely identify each document in a MongoDB collection.
  2. Step 2: Differentiate from other identifiers

    It is not a session ID, random number, or database creation timestamp but a unique document ID.
  3. Final Answer:

    A unique identifier for documents in a collection -> Option B
  4. Quick Check:

    ObjectId = Unique document ID [OK]
Hint: ObjectId is always a unique document ID in MongoDB [OK]
Common Mistakes:
  • Thinking ObjectId is a random number
  • Confusing ObjectId with session or user IDs
  • Assuming it stores database creation time
2. Which of the following is the correct way to create a new ObjectId in MongoDB using the shell?
easy
A. ObjectId()
B. ObjectId.new()
C. new ObjectId()
D. create ObjectId()

Solution

  1. Step 1: Recall MongoDB shell syntax

    In the MongoDB shell, new ObjectId() is used to create a new ObjectId instance.
  2. Step 2: Check other options for syntax errors

    Options B, C, and D use incorrect syntax or are invalid in MongoDB shell.
  3. Final Answer:

    new ObjectId() -> Option C
  4. Quick Check:

    Use new ObjectId() to create new IDs [OK]
Hint: Use new ObjectId() in MongoDB shell [OK]
Common Mistakes:
  • Using ObjectId() without new keyword
  • Trying to call ObjectId as a method
  • Using create keyword which is invalid
3. Given the following code snippet in MongoDB shell:
var id = ObjectId();
var timestamp = id.getTimestamp();
print(timestamp);

What does timestamp represent?
medium
A. The creation time of the ObjectId
B. The current system time when print runs
C. The last modified time of the document
D. The expiration time of the ObjectId

Solution

  1. Step 1: Understand ObjectId structure

    ObjectId contains a timestamp of when it was created embedded in its first 4 bytes.
  2. Step 2: Explain getTimestamp() method

    The getTimestamp() method extracts this creation time from the ObjectId.
  3. Final Answer:

    The creation time of the ObjectId -> Option A
  4. Quick Check:

    getTimestamp() = ObjectId creation time [OK]
Hint: getTimestamp() returns ObjectId creation time [OK]
Common Mistakes:
  • Assuming it returns current time
  • Confusing with document modification time
  • Thinking it returns expiration time
4. You wrote this code in MongoDB shell:
var id = ObjectId.getTimestamp();

But it throws an error. What is the problem?
medium
A. getTimestamp() is not a static method of ObjectId
B. ObjectId is not defined in MongoDB shell
C. You must pass an argument to getTimestamp()
D. ObjectId.getTimestamp() returns a promise and needs await

Solution

  1. Step 1: Check method usage

    getTimestamp() is an instance method, not a static method on ObjectId class.
  2. Step 2: Correct usage

    You must create an ObjectId instance first, then call id.getTimestamp().
  3. Final Answer:

    getTimestamp() is not a static method of ObjectId -> Option A
  4. Quick Check:

    getTimestamp() needs ObjectId instance [OK]
Hint: Call getTimestamp() on ObjectId instance, not class [OK]
Common Mistakes:
  • Calling getTimestamp() directly on ObjectId
  • Forgetting to create ObjectId instance
  • Expecting getTimestamp() to be async
5. You want to generate a MongoDB ObjectId that corresponds to a specific timestamp (e.g., Jan 1, 2020). Which approach is correct?
hard
A. Create an ObjectId with the timestamp bytes set, then fill remaining bytes with zeros
B. Use ObjectId() constructor with a date string argument
C. Manually convert the date to hex and concatenate with random bytes
D. Use ObjectId.createFromTime(timestampInSeconds)

Solution

  1. Step 1: Understand ObjectId creation from timestamp

    MongoDB provides ObjectId.createFromTime() to create an ObjectId from a Unix timestamp in seconds.
  2. Step 2: Evaluate other options

    Options C and D are manual and error-prone; B is invalid as ObjectId constructor does not accept date strings.
  3. Final Answer:

    Use ObjectId.createFromTime(timestampInSeconds) -> Option D
  4. Quick Check:

    createFromTime() creates ObjectId from timestamp [OK]
Hint: Use createFromTime() to make ObjectId from timestamp [OK]
Common Mistakes:
  • Trying to pass date string to ObjectId()
  • Manually building ObjectId hex string
  • Ignoring built-in createFromTime() method