KEMBAR78
MongoDB Reference Manual PDF | PDF | Mongo Db | Database Index
100% found this document useful (2 votes)
716 views787 pages

MongoDB Reference Manual PDF

Uploaded by

Dante Llimpe
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
100% found this document useful (2 votes)
716 views787 pages

MongoDB Reference Manual PDF

Uploaded by

Dante Llimpe
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 787

MongoDB Reference Manual

Release 2.6.4
MongoDB Documentation Project
September 16, 2014
2
Contents
1 About MongoDB Documentation 3
1.1 License . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.2 Editions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.3 Version and Revisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.4 Report an Issue or Make a Change Request . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.5 Contribute to the Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
2 Interfaces Reference 21
2.1 mongo Shell Methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.2 Database Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 208
2.3 Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 386
2.4 Aggregation Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 536
3 MongoDB and SQL Interface Comparisons 547
3.1 SQL to MongoDB Mapping Chart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547
3.2 SQL to Aggregation Mapping Chart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 552
4 Program and Tool Reference Pages 555
4.1 MongoDB Package Components . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 555
5 Internal Metadata 647
5.1 Cong Database . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 647
5.2 The local Database . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 652
5.3 System Collections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 654
6 General System Reference 657
6.1 Exit Codes and Statuses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 657
6.2 MongoDB Limits and Thresholds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 658
6.3 Glossary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 663
7 Release Notes 675
7.1 Current Stable Release . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 675
7.2 Previous Stable Releases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 713
7.3 Other MongoDB Release Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 759
Index 761
i
ii
MongoDB Reference Manual, Release 2.6.4
This document contains all of the reference material from the MongoDB Manual, reecting the 2.6.4 release. See
the full manual, for complete documentation of MongoDB, its operation, and use.
Contents 1
MongoDB Reference Manual, Release 2.6.4
2 Contents
CHAPTER 1
About MongoDB Documentation
The MongoDB Manual
1
contains comprehensive documentation on the MongoDB document-oriented database man-
agement system. This page describes the manuals licensing, editions, and versions, and describes how to make a
change request and how to contribute to the manual.
For more information on MongoDB, see MongoDB: A Document Oriented Database
2
. To download MongoDB, see
the downloads page
3
.
1.1 License
This manual is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported
4
(i.e.
CC-BY-NC-SA) license.
The MongoDB Manual is copyright 2011-2014 MongoDB, Inc.
1.2 Editions
In addition to the MongoDB Manual
5
, you can also access this content in the following editions:
ePub Format
6
Single HTML Page
7
PDF Format
8
(without reference.)
HTML tar.gz
9
You also can access PDF les that contain subsets of the MongoDB Manual:
MongoDB Reference Manual
10
MongoDB CRUD Operations
11
1
http://docs.mongodb.org/manual/#
2
http://www.mongodb.org/about/
3
http://www.mongodb.org/downloads
4
http://creativecommons.org/licenses/by-nc-sa/3.0/
5
http://docs.mongodb.org/manual/#
6
http://docs.mongodb.org/master/MongoDB-manual.epub
7
http://docs.mongodb.org/master/single/
8
http://docs.mongodb.org/master/MongoDB-manual.pdf
9
http://docs.mongodb.org/master/manual.tar.gz
10
http://docs.mongodb.org/master/MongoDB-reference-manual.pdf
11
http://docs.mongodb.org/master/MongoDB-crud-guide.pdf
3
MongoDB Reference Manual, Release 2.6.4
Data Models for MongoDB
12
MongoDB Data Aggregation
13
Replication and MongoDB
14
Sharding and MongoDB
15
MongoDB Administration
16
MongoDB Security
17
MongoDB Reference documentation is also available as part of dash
18
. You can also access the MongoDB Man
Pages
19
which are also distributed with the ofcial MongoDB Packages.
1.3 Version and Revisions
This version of the manual reects version 2.6 of MongoDB.
See the MongoDB Documentation Project Page
20
for an overview of all editions and output formats of the MongoDB
Manual. You can see the full revision history and track ongoing improvements and additions for all versions of the
manual from its GitHub repository
21
.
This edition reects master branch of the documentation as of the
6b5d51a49f42f8c4046a3bd277c5b24840a24e87 revision. This branch is explicitly accessible via
http://docs.mongodb.org/master and you can always reference the commit of the current manual in the release.txt
22
le.
The most up-to-date, current, and stable version of the manual is always available at
http://docs.mongodb.org/manual/.
1.4 Report an Issue or Make a Change Request
To report an issue with this manual or to make a change request, le a ticket at the MongoDB DOCS Project on Jira
23
.
1.5 Contribute to the Documentation
1.5.1 MongoDB Manual Translation
The original language of all MongoDB documentation is American English. However it is of critical importance to
the documentation project to ensure that speakers of other languages can read and understand the documentation.
12
http://docs.mongodb.org/master/MongoDB-data-models-guide.pdf
13
http://docs.mongodb.org/master/MongoDB-aggregation-guide.pdf
14
http://docs.mongodb.org/master/MongoDB-replication-guide.pdf
15
http://docs.mongodb.org/master/MongoDB-sharding-guide.pdf
16
http://docs.mongodb.org/master/MongoDB-administration-guide.pdf
17
http://docs.mongodb.org/master/MongoDB-security-guide.pdf
18
http://kapeli.com/dash
19
http://docs.mongodb.org/master/manpages.tar.gz
20
http://docs.mongodb.org
21
https://github.com/mongodb/docs
22
http://docs.mongodb.org/master/release.txt
23
https://jira.mongodb.org/browse/DOCS
4 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
To this end, the MongoDB Documentation Project is preparing to launch a translation effort to allow the community
to help bring the documentation to speakers of other languages.
If you would like to express interest in helping to translate the MongoDB documentation once this project is opened
to the public, please:
complete the MongoDB Contributor Agreement
24
, and
join the mongodb-translators
25
user group.
The mongodb-translators
26
user group exists to facilitate collaboration between translators and the documentation
team at large. You can join the group without signing the Contributor Agreement, but you will not be allowed to
contribute translations.
See also:
Contribute to the Documentation (page 4)
Style Guide and Documentation Conventions (page 6)
MongoDB Manual Organization (page 15)
MongoDB Documentation Practices and Processes (page 12)
MongoDB Documentation Build System (page 16)
The entire documentation source for this manual is available in the mongodb/docs repository
27
, which is one of the
MongoDB project repositories on GitHub
28
.
To contribute to the documentation, you can open a GitHub account
29
, fork the mongodb/docs repository
30
, make a
change, and issue a pull request.
In order for the documentation team to accept your change, you must complete the MongoDB Contributor Agree-
ment
31
.
You can clone the repository by issuing the following command at your system shell:
git clone git://github.com/mongodb/docs.git
1.5.2 About the Documentation Process
The MongoDB Manual uses Sphinx
32
, a sophisticated documentation engine built upon Python Docutils
33
. The orig-
inal reStructured Text
34
les, as well as all necessary Sphinx extensions and build tools, are available in the same
repository as the documentation.
For more information on the MongoDB documentation process, see:
24
http://www.mongodb.com/legal/contributor-agreement
25
http://groups.google.com/group/mongodb-translators
26
http://groups.google.com/group/mongodb-translators
27
https://github.com/mongodb/docs
28
http://github.com/mongodb
29
https://github.com/
30
https://github.com/mongodb/docs
31
http://www.mongodb.com/contributor
32
http://sphinx-doc.org//
33
http://docutils.sourceforge.net/
34
http://docutils.sourceforge.net/rst.html
1.5. Contribute to the Documentation 5
MongoDB Reference Manual, Release 2.6.4
Style Guide and Documentation Conventions
This document provides an overview of the style for the MongoDB documentation stored in this repository. The
overarching goal of this style guide is to provide an accessible base style to ensure that our documentation is easy to
read, simple to use, and straightforward to maintain.
For information regarding the MongoDB Manual organization, see MongoDB Manual Organization (page 15).
Document History
2011-09-27: Document created with a (very) rough list of style guidelines, conventions, and questions.
2012-01-12: Document revised based on slight shifts in practice, and as part of an effort of making it easier for people
outside of the documentation team to contribute to documentation.
2012-03-21: Merged in content from the Jargon, and cleaned up style in light of recent experiences.
2012-08-10: Addition to the Referencing section.
2013-02-07: Migrated this document to the manual. Added map-reduce terminology convention. Other edits.
2013-11-15: Added new table of preferred terms.
Naming Conventions
This section contains guidelines on naming les, sections, documents and other document elements.
File naming Convention:
For Sphinx, all les should have a .txt extension.
Separate words in le names with hyphens (i.e. -.)
For most documents, le names should have a terse one or two word name that de-
scribes the material covered in the document. Allow the path of the le within the doc-
ument tree to add some of the required context/categorization. For example its ac-
ceptable to have http://docs.mongodb.org/manualcore/sharding.rst and
http://docs.mongodb.org/manualadministration/sharding.rst.
For tutorials, the full title of the document should be in the le name. For example,
http://docs.mongodb.org/manualtutorial/replace-one-configuration-server-in-a-shard-cluster.rst
Phrase headlines and titles so users can determine what questions the text will answer, and material that will
be addressed, without needing them to read the content. This shortens the amount of time that people spend
looking for answers, and improvise search/scanning, and possibly SEO.
Prefer titles and headers in the form of Using foo over How to Foo.
When using target references (i.e. :ref: references in documents), use names that include enough context to
be intelligible through all documentation. For example, use replica-set-secondary-only-node as
opposed to secondary-only-node. This makes the source more usable and easier to maintain.
Style Guide
This includes the local typesetting, English, grammatical, conventions and preferences that all documents in the manual
should use. The goal here is to choose good standards, that are clear, and have a stylistic minimalism that does not
interfere with or distract from the content. A uniform style will improve user experience and minimize the effect of a
multi-authored document.
6 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
Punctuation
Use the Oxford comma.
Oxford commas are the commas in a list of things (e.g. something, something else, and another thing) before
the conjunction (e.g. and or or.).
Do not add two spaces after terminal punctuation, such as periods.
Place commas and periods inside quotation marks.
Headings Use title case for headings and document titles. Title case capitalizes the rst letter of the rst, last, and
all signicant words.
Verbs Verb tense and mood preferences, with examples:
Avoid the rst person. For example do not say, We will begin the backup process by locking the database, or
I begin the backup process by locking my database instance.
Use the second person. If you need to back up your database, start by locking the database rst. In practice,
however, its more concise to imply second person using the imperative, as in Before initiating a backup, lock
the database.
When indicated, use the imperative mood. For example: Backup your databases often and To prevent data
loss, back up your databases.
The future perfect is also useful in some cases. For example, Creating disk snapshots without locking the
database will lead to an invalid state.
Avoid helper verbs, as possible, to increase clarity and concision. For example, attempt to avoid this does
foo and this will do foo when possible. Use does foo over will do foo in situations where this foos is
unacceptable.
Referencing
To refer to future or planned functionality in MongoDB or a driver, always link to the Jira case. The Manuals
conf.py provides an :issue: role that links directly to a Jira case (e.g. :issue:\SERVER-9001\).
For non-object references (i.e. functions, operators, methods, database commands, settings) always reference
only the rst occurrence of the reference in a section. You should always reference objects, except in section
headings.
Structure references with the why rst; the link second.
For example, instead of this:
Use the http://docs.mongodb.org/manualtutorial/convert-replica-set-to-replicated-shard-cluster
procedure if you have an existing replica set.
Type this:
To deploy a sharded cluster for an existing replica set, see http://docs.mongodb.org/manualtutorial/convert-replica-set-to-replicated-shard-cluster.
General Formulations
Contractions are acceptable insofar as they are necessary to increase readability and ow. Avoid otherwise.
Make lists grammatically correct.
Do not use a period after every item unless the list item completes the unnished sentence before the list.
1.5. Contribute to the Documentation 7
MongoDB Reference Manual, Release 2.6.4
Use appropriate commas and conjunctions in the list items.
Typically begin a bulleted list with an introductory sentence or clause, with a colon or comma.
The following terms are one word:
standalone
workow
Use unavailable, ofine, or unreachable to refer to a mongod instance that cannot be accessed. Do not
use the colloquialism down.
Always write out units (e.g. megabytes) rather than using abbreviations (e.g. MB.)
Structural Formulations
There should be at least two headings at every nesting level. Within an h2 block, there should be either: no
h3 blocks, 2 h3 blocks, or more than 2 h3 blocks.
Section headers are in title case (capitalize rst, last, and all important words) and should effectively describe
the contents of the section. In a single document you should strive to have section titles that are not redundant
and grammatically consistent with each other.
Use paragraphs and paragraph breaks to increase clarity and ow. Avoid burying critical information in the
middle of long paragraphs. Err on the side of shorter paragraphs.
Prefer shorter sentences to longer sentences. Use complex formations only as a last resort, if at all (e.g. com-
pound complex structures that require semi-colons).
Avoid paragraphs that consist of single sentences as they often represent a sentence that has unintentionally
become too complex or incomplete. However, sometimes such paragraphs are useful for emphasis, summary,
or introductions.
As a corollary, most sections should have multiple paragraphs.
For longer lists and more complex lists, use bulleted items rather than integrating them inline into a sentence.
Do not expect that the content of any example (inline or blocked) will be self explanatory. Even when it feels
redundant, make sure that the function and use of every example is clearly described.
ReStructured Text and Typesetting
Place spaces between nested parentheticals and elements in JavaScript examples. For example, prefer { [ a,
a, a ] } over {[a,a,a]}.
For underlines associated with headers in RST, use:
= for heading level 1 or h1s. Use underlines and overlines for document titles.
- for heading level 2 or h2s.
~ for heading level 3 or h3s.
for heading level 4 or h4s.
Use hyphens (-) to indicate items of an ordered list.
Place footnotes and other references, if you use them, at the end of a section rather than the end of a le.
Use the footnote format that includes automatic numbering and a target name for ease of use. For instance a
footnote tag may look like: [#note]_ with the corresponding directive holding the body of the footnote that
resembles the following: .. [#note].
Do not include .. code-block:: [language] in footnotes.
8 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
As it makes sense, use the .. code-block:: [language] form to insert literal blocks into the text.
While the double colon, ::, is functional, the .. code-block:: [language] form makes the source
easier to read and understand.
For all mentions of referenced types (i.e. commands, operators, expressions, functions, statuses, etc.) use the
reference types to ensure uniform formatting and cross-referencing.
1.5. Contribute to the Documentation 9
MongoDB Reference Manual, Release 2.6.4
10 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
Jargon and Common Terms
Pre-
ferred
Term
Concept Dispreferred
Alternatives
Notes
docu-
ment
A single, top-level object/record
in a MongoDB collection.
record, object,
row
Prefer document over object because of
concerns about cross-driver language handling
of objects. Reserve record for allocation of
storage. Avoid row, as possible.
databaseA group of collections. Refers to
a group of data les. This is the
logical sense of the term
database.
Avoid genericizing database. Avoid using
database to refer to a server process or a data
set. This applies both to the datastoring
contexts as well as other (related) operational
contexts (command context,
authentication/authorization context.)
in-
stance
A daemon process. (e.g. mongos
or mongod)
process
(acceptable
sometimes), node
(never
acceptable),
server.
Avoid using instance, unless it modies
something specically. Having a descriptor for
a process/instance makes it possible to avoid
needing to make mongod or mongos plural.
Server and node are both vague and
contextually difcult to disambiguate with
regards to application servers, and underlying
hardware.
eld
name
The identier of a value in a
document.
key, column Avoid introducing unrelated terms for a single
eld. In the documentation weve rarely had to
discuss the identier of a eld, so the extra
word here isnt burdensome.
eld/value The name/value pair that
describes a unit of data in
MongoDB.
key, slot, attribute Use to emphasize the difference between the
name of a eld and its value For example,
_id is the eld and the default value is an
ObjectId.
value The data content of a eld. data
Mon-
goDB
A group of processes, or
deployment that implement the
MongoDB interface.
mongo,
mongodb, cluster
Stylistic preference, mostly. In some cases its
useful to be able to refer generically to
instances (that may be either mongod or
mongos.)
sub-
document
An embedded or nested
document within a document or
an array.
embedded
document, nested
document
map-
reduce
An operation performed by the
mapReduce command.
mapReduce, map
reduce,
map/reduce
Avoid confusion with the command, shell
helper, and driver interfaces. Makes it possible
to discuss the operation generally.
clus-
ter
A sharded cluster. grid, shard
cluster, set,
deployment
Cluster is a great word for a group of
processes; however, its important to avoid
letting the term become generic. Do not use for
any group of MongoDB processes or
deployments.
sharded
clus-
ter
A sharded cluster. shard cluster,
cluster, sharded
system
replica
set
A deployment of replicating
mongod programs that provide
redundancy and automatic
failover.
set, replication
deployment
de-
ploy-
ment
A group of MongoDB processes,
or a standalone mongod
instance.
cluster, system Typically in the form MongoDB deployment.
Includes standalones, replica sets and sharded
clusters.
data
set
The collection of physical
databases provided by a
MongoDB deployment.
database, data Important to keep the distinction between the
data provided by a mongod or a sharded cluster
as distinct from each database (i.e. a logical
database that refers to a group of collections
stored in a single series of data les.)
pri-
mary
The only member of a replica set
that can accept writes.
master Avoid primary member construction.
sec-
ondary
Read-only members of a replica
set that apply operations from the
primarys oplog.
slave Accept secondary member as needed.
pri-
mary
shard
The shard in a cluster thats
primary for a database.
primary Avoid ambiguity with primary in the context of
replica sets.
range
based
shard-
ing
Refers to sharding based on
regular shard keys where the
range is the value of the eld(s)
selected as the shard key.
hash
based
shard-
ing
Refers to sharding based on
hashed shard keys where the
range is the hashed value of the
eld selected as the shard key.
Even though hashed sharding is based on
ranges of hashes, the sequence of hashes arent
meaningful to users, and the range-based
aspect of hashed shard keys is an
implementation detail.
shard-
ing
Describes the practice of
horizontal scaling or partitioning
as implemented in sharded
clusters.
partitioning,
horizontal scaling
Only use the terms partitioning and
horizontal scaling to describe what sharding
does, and its operation. Dont refer to sharding
as the partitioning system.
meta-
data
data about data meta-data, meta
data
1.5. Contribute to the Documentation 11
MongoDB Reference Manual, Release 2.6.4
Database Systems and Processes
To indicate the entire database system, use MongoDB, not mongo or Mongo.
To indicate the database process or a server instance, use mongod or mongos. Refer to these as processes
or instances. Reserve database for referring to a database structure, i.e., the structure that holds collections
and refers to a group of les on disk.
Distributed System Terms
Refer to partitioned systems as sharded clusters. Do not use shard clusters or sharded systems.
Refer to congurations that run with replication as replica sets (or master/slave deployments) rather than
clusters or other variants.
Data Structure Terms
document refers to rows or records in a MongoDB database. Potential confusion with JSON Docu-
ments.
Do not refer to documents as objects, because drivers (and MongoDB) do not preserve the order of elds when
fetching data. If the order of objects matter, use an array.
eld refers to a key or identier of data within a MongoDB document.
value refers to the contents of a eld.
sub-document describes a nested document.
Other Terms
Use example.net (and .org or .com if needed) for all examples and samples.
Hyphenate map-reduce in order to avoid ambiguous reference to the command name. Do not camel-case.
Notes on Specic Features
Geo-Location
1. While MongoDB is capable of storing coordinates in sub-documents, in practice, users should only store
coordinates in arrays. (See: DOCS-41
35
.)
MongoDB Documentation Practices and Processes
This document provides an overview of the practices and processes.
Commits
When relevant, include a Jira case identier in a commit message. Reference documentation cases when applicable,
but feel free to reference other cases from jira.mongodb.org
36
.
Err on the side of creating a larger number of discrete commits rather than bundling large set of changes into one
commit.
35
https://jira.mongodb.org/browse/DOCS-41
36
http://jira.mongodb.org/
12 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
For the sake of consistency, remove trailing whitespaces in the source le.
Hard wrap les to between 72 and 80 characters per-line.
Standards and Practices
At least two people should vet all non-trivial changes to the documentation before publication. One of the
reviewers should have signicant technical experience with the material covered in the documentation.
All development and editorial work should transpire on GitHub branches or forks that editors can then merge
into the publication branches.
Collaboration
To propose a change to the documentation, do either of the following:
Open a ticket in the documentation project
37
proposing the change. Someone on the documentation team will
make the change and be in contact with you so that you can review the change.
Using GitHub
38
, fork the mongodb/docs repository
39
, commit your changes, and issue a pull request. Someone
on the documentation team will review and incorporate your change into the documentation.
Builds
Building the documentation is useful because Sphinx
40
and docutils can catch numerous errors in the format and
syntax of the documentation. Additionally, having access to an example documentation as it will appear to the users
is useful for providing more effective basis for the review process. Besides Sphinx, Pygments, and Python-Docutils,
the documentation repository contains all requirements for building the documentation resource.
Talk to someone on the documentation team if you are having problems running builds yourself.
Publication
The makele for this repository contains targets that automate the publication process. Use make html to publish
a test build of the documentation in the build/ directory of your repository. Use make publish to build the full
contents of the manual from the current branch in the ../public-docs/ directory relative the docs repository.
Other targets include:
man - builds UNIX Manual pages for all Mongodb utilities.
push - builds and deploys the contents of the ../public-docs/.
pdfs - builds a PDF version of the manual (requires LaTeX dependencies.)
Branches
This section provides an overview of the git branches in the MongoDB documentation repository and their use.
37
https://jira.mongodb.org/browse/DOCS
38
https://github.com/
39
https://github.com/mongodb/docs
40
http://sphinx.pocoo.org/
1.5. Contribute to the Documentation 13
MongoDB Reference Manual, Release 2.6.4
At the present time, future work transpires in the master, with the main publication being current. As the
documentation stabilizes, the documentation team will begin to maintain branches of the documentation for specic
MongoDB releases.
Migration from Legacy Documentation
The MongoDB.org Wiki contains a wealth of information. As the transition to the Manual (i.e. this project and
resource) continues, its critical that no information disappears or goes missing. The following process outlines how
to migrate a wiki page to the manual:
1. Read the relevant sections of the Manual, and see what the new documentation has to offer on a specic topic.
In this process you should follow cross references and gain an understanding of both the underlying information
and how the parts of the new content relates its constituent parts.
2. Read the wiki page you wish to redirect, and take note of all of the factual assertions, examples presented by the
wiki page.
3. Test the factual assertions of the wiki page to the greatest extent possible. Ensure that example output is accurate.
In the case of commands and reference material, make sure that documented options are accurate.
4. Make corrections to the manual page or pages to reect any missing pieces of information.
The target of the redirect need not contain every piece of information on the wiki page, if the manual as a
whole does, and relevant section(s) with the information from the wiki page are accessible from the target of the
redirection.
5. As necessary, get these changes reviewed by another writer and/or someone familiar with the area of the infor-
mation in question.
At this point, update the relevant Jira case with the target that youve chosen for the redirect, and make the ticket
unassigned.
6. When someone has reviewed the changes and published those changes to Manual, you, or preferably someone
else on the team, should make a nal pass at both pages with fresh eyes and then make the redirect.
Steps 1-5 should ensure that no information is lost in the migration, and that the nal review in step 6 should be
trivial to complete.
Review Process
Types of Review The content in the Manual undergoes many types of review, including the following:
Initial Technical Review Review by an engineer familiar with MongoDB and the topic area of the documentation.
This review focuses on technical content, and correctness of the procedures and facts presented, but can improve any
aspect of the documentation that may still be lacking. When both the initial technical review and the content review
are complete, the piece may be published.
Content Review Textual review by another writer to ensure stylistic consistency with the rest of the manual. De-
pending on the content, this may precede or follow the initial technical review. When both the initial technical review
and the content review are complete, the piece may be published.
14 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
Consistency Review This occurs post-publication and is content focused. The goals of consistency reviews are to
increase the internal consistency of the documentation as a whole. Insert relevant cross-references, update the style as
needed, and provide background fact-checking.
When possible, consistency reviews should be as systematic as possible and we should avoid encouraging stylistic and
information drift by editing only small sections at a time.
Subsequent Technical Review If the documentation needs to be updated following a change in functionality of the
server or following the resolution of a user issue, changes may be signicant enough to warrant additional technical
review. These reviews follow the same form as the initial technical review, but is often less involved and covers a
smaller area.
Review Methods If youre not a usual contributor to the documentation and would like to review something, you
can submit reviews in any of the following methods:
If youre reviewing an open pull request in GitHub, the best way to comment is on the overview diff, which
you can nd by clicking on the diff button in the upper left portion of the screen. You can also use the
following URL to reach this interface:
https://github.com/mongodb/docs/pull/[pull-request-id]/files
Replace [pull-request-id] with the identier of the pull request. Make all comments inline, using
GitHubs comment system.
You may also provide comments directly on commits, or on the pull request itself but these commit-comments
are archived in less coherent ways and generate less useful emails, while comments on the pull request lead to
less specic changes to the document.
Leave feedback on Jira cases in the DOCS
41
project. These are better for more general changes that arent
necessarily tied to a specic line, or affect multiple les.
Create a fork of the repository in your GitHub account, make any required changes and then create a pull request
with your changes.
If you insert lines that begin with any of the following annotations:
.. TODO:
TODO:
.. TODO
TODO
followed by your comments, it will be easier for the original writer to locate your comments. The two dots ..
format is a comment in reStructured Text, which will hide your comments from Sphinx and publication if youre
worried about that.
This format is often easier for reviewers with larger portions of content to review.
MongoDB Manual Organization
This document provides an overview of the global organization of the documentation resource. Refer to the notes
below if you are having trouble understanding the reasoning behind a les current location, or if you want to add new
documentation but arent sure how to integrate it into the existing resource.
If you have questions, dont hesitate to open a ticket in the Documentation Jira Project
42
or contact the documentation
team
43
.
41
http://jira.mongodb.org/browse/DOCS
42
https://jira.mongodb.org/browse/DOCS
43
docs@mongodb.com
1.5. Contribute to the Documentation 15
MongoDB Reference Manual, Release 2.6.4
Global Organization
Indexes and Experience The documentation project has two index les:
http://docs.mongodb.org/manualcontents.txt and http://docs.mongodb.org/manualindex.txt.
The contents le provides the documentations tree structure, which Sphinx uses to create the left-pane navigational
structure, to power the Next and Previous page functionality, and to provide all overarching outlines of the
resource. The index le is not included in the contents le (and thus builds will produce a warning here) and is
the page that users rst land on when visiting the resource.
Having separate contents and index les provides a bit more exibility with the organization of the resource while
also making it possible to customize the primary user experience.
Topical Organization The placement of les in the repository depends on the type of documentation rather than the
topic of the content. Like the difference between contents.txt and index.txt, by decoupling the organization
of the les from the organization of the information the documentation can be more exible and can more adequately
address changes in the product and in users needs.
Files in the source/ directory represent the tip of a logical tree of documents, while directories are containers of
types of content. The administration and applications directories, however, are legacy artifacts and with a
few exceptions contain sub-navigation pages.
With several exceptions in the reference/ directory, there is only one level of sub-directories in the source/
directory.
Tools
The organization of the site, like all Sphinx sites derives from the toctree
44
structure. However, in order to annotate
the table of contents and provide additional exibility, the MongoDB documentation generates toctree
45
structures
using data from YAML les stored in the source/includes/ directory. These les start with ref-toc or toc
and generate output in the source/includes/toc/ directory. Briey this system has the following behavior:
les that start with ref-toc refer to the documentation of API objects (i.e. commands, operators and methods),
and the build system generates les that hold toctree
46
directives as well as les that hold tables that list
objects and a brief description.
les that start with toc refer to all other documentation and the build system generates les that hold
toctree
47
directives as well as les that hold denition lists that contain links to the documents and short
descriptions the content.
le names that have spec following toc or ref-toc will generate aggregated tables or denition lists and
allow ad-hoc combinations of documents for landing pages and quick reference guides.
MongoDB Documentation Build System
This document contains more direct instructions for building the MongoDB documentation.
Getting Started
Install Dependencies The MongoDB Documentation project depends on the following tools:
44
http://sphinx-doc.org/markup/toctree.html#directive-toctree
45
http://sphinx-doc.org/markup/toctree.html#directive-toctree
46
http://sphinx-doc.org/markup/toctree.html#directive-toctree
47
http://sphinx-doc.org/markup/toctree.html#directive-toctree
16 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
GNU Make
GNU Tar
Python
Git
Sphinx (documentation management toolchain)
Pygments (syntax highlighting)
PyYAML (for the generated tables)
Droopy (Python package for static text analysis)
Fabric (Python package for scripting and orchestration)
Inkscape (Image generation.)
python-argparse (For Python 2.6.)
LaTeX/PDF LaTeX (typically texlive; for building PDFs)
Common Utilities (rsync, tar, gzip, sed)
OS X Install Sphinx, Docutils, and their dependencies with easy_install the following command:
easy_install Sphinx Jinja2 Pygments docutils PyYAML droopy fabric
Feel free to use pip rather than easy_install to install python packages.
To generate the images used in the documentation, download and install Inkscape
48
.
Optional
To generate PDFs for the full production build, install a TeX distribution (for building the PDF.) If you do not have a
LaTeX installation, use MacTeX
49
. This is only required to build PDFs.
Arch Linux Install packages from the system repositories with the following command:
pacman -S python2-sphinx python2-yaml inkscape python2-pip
Then install the following Python packages:
pip install droopy fabric
Optional
To generate PDFs for the full production build, install the following packages from the system repository:
pacman -S texlive-bin texlive-core texlive-latexextra
Debian/Ubuntu Install the required system packages with the following command:
apt-get install python-sphinx python-yaml python-argparse inkscape python-pip
Then install the following Python packages:
48
http://inkscape.org/download/
49
http://www.tug.org/mactex/2011/
1.5. Contribute to the Documentation 17
MongoDB Reference Manual, Release 2.6.4
pip install droopy fabric
Optional
To generate PDFs for the full production build, install the following packages from the system repository:
apt-get install texlive-latex-recommended texlive-latex-recommended
Setup and Conguration Clone the repository:
git clone git://github.com/mongodb/docs.git
Then run the bootstrap.py script in the docs/ repository, to congure the build dependencies:
python bootstrap.py
This downloads and congures the mongodb/docs-tools
50
repository, which contains the authoritative build system
shared between branches of the MongoDB Manual and other MongoDB documentation projects.
You can run bootstrap.py regularly to update build system.
Building the Documentation
The MongoDB documentation build system is entirely accessible via make targets. For example, to build an HTML
version of the documentation issue the following command:
make html
You can nd the build output in build/<branch>/html, where <branch> is the name of the current branch.
In addition to the html target, the build system provides the following targets:
publish Builds and integrates all output for the production build. Build output is in
build/public/<branch>/. When you run publish in the master, the build will generate
some output in build/public/.
push; stage Uploads the production build to the production or staging web servers. Depends on publish. Re-
quires access production or staging environment.
push-all; stage-all Uploads the entire content of build/public/ to the web servers. Depends on
publish. Not used in common practice.
push-with-delete; stage-with-delete Modies the action of push and stage to remove remote le
that dont exist in the local build. Use with caution.
html; latex; dirhtml; epub; texinfo; man; json These are standard targets derived from the default
Sphinx Makele, with adjusted dependencies. Additionally, for all of these targets you can append -nitpick
to increase Sphinxs verbosity, or -clean to remove all Sphinx build artifacts.
latex performs several additional post-processing steps on .tex output generated by Sphinx. This target will
also compile PDFs using pdflatex.
html and man also generates a .tar.gz le of the build outputs for inclusion in the nal releases.
50
http://github.com/mongodb/docs-tools/
18 Chapter 1. About MongoDB Documentation
MongoDB Reference Manual, Release 2.6.4
Build Mechanics and Tools
Internally the build system has a number of components and processes. See the docs-tools README
51
for more
information on the internals. This section documents a few of these components from a very high level and lists useful
operations for contributors to the documentation.
Fabric Fabric is an orchestration and scripting package for Python. The documentation uses Fabric to handle the
deployment of the build products to the web servers and also unies a number of independent build operations. Fabric
commands have the following form:
fab <module>.<task>[:<argument>]
The <argument> is optional in most cases. Additionally some tasks are available at the root level, without a module.
To see a full list of fabric tasks, use the following command:
fab -l
You can chain fabric tasks on a single command line, although this doesnt always make sense.
Important fabric tasks include:
tools.bootstrap Runs the bootstrap.py script. Useful for re-initializing the repository without needing to
be in root of the repository.
tools.dev; tools.reset tools.dev switches the origin remote of the docs-tools checkout in build
directory, to ../docs-tools to facilitate build system testing and development. tools.reset resets the
origin remote for normal operation.
tools.conf tools.conf returns the content of the conguration object for the current project. These data are
useful during development.
stats.report:<filename> Returns, a collection of readability statistics. Specify le names relative to
source/ tree.
make Provides a thin wrapper around Make calls. Allows you to start make builds from different locations in the
project repository.
process.refresh_dependencies Updates the time stamp of .txt source les with changed include les, to
facilitate Sphinxs incremental rebuild process. This task runs internally as part of the build process.
Buildcloth Buildcloth
52
is a meta-build tool, used to generate Makeles programmatically. This makes the build
system easier to maintain, and makes it easier to use the same fundamental code to generate various branches of the
Manual as well as related documentation projects. See makecloth/ in the docs-tools repository
53
for the relevant code.
Running make with no arguments will regenerate these parts of the build system automatically.
Rstcloth Rstcloth
54
is a library for generating reStructuredText programmatically. This makes it possible to generate
content for the documentation, such as tables, tables of contents, and API reference material programmatically and
transparently. See rstcloth/ in the docs-tools repository
55
for the relevant code.
If you have any questions, please feel free to open a Jira Case
56
.
51
https://github.com/mongodb/docs-tools/blob/master/README.rst
52
https://pypi.python.org/pypi/buildcloth/
53
https://github.com/mongodb/docs-tools/tree/master/makecloth
54
https://pypi.python.org/pypi/rstcloth
55
https://github.com/mongodb/docs-tools/tree/master/rstcloth
56
https://jira.mongodb.org/browse/DOCS
1.5. Contribute to the Documentation 19
MongoDB Reference Manual, Release 2.6.4
20 Chapter 1. About MongoDB Documentation
CHAPTER 2
Interfaces Reference
2.1 mongo Shell Methods
JavaScript in MongoDB
Although these methods use JavaScript, most interactions with MongoDB do not use JavaScript but use an
idiomatic driver in the language of the interacting application.
2.1.1 Collection
Collection Methods
Name Description
db.collection.aggregate() (page 22) Provides access to the aggregation pipeline.
db.collection.copyTo() (page 25) Wraps eval (page 235) to copy data between collections in a single MongoDB instance.
db.collection.count() (page 26) Wraps count (page 211) to return a count of the number of documents in a collection or matching a query.
db.collection.createIndex() (page 27) Builds an index on a collection. Use db.collection.ensureIndex() (page 30).
db.collection.dataSize() (page 28) Returns the size of the collection. Wraps the size (page 338) eld in the output of the collStats (page 338).
db.collection.distinct() (page 28) Returns an array of documents that have distinct values for the specied eld.
db.collection.drop() (page 28) Removes the specied collection from the database.
db.collection.dropIndex() (page 29) Removes a specied index on a collection.
db.collection.dropIndexes() (page 30) Removes all indexes on a collection.
db.collection.ensureIndex() (page 30) Creates an index if it does not currently exist. If the index exists ensureIndex() (page 30) does nothing.
db.collection.find() (page 33) Performs a query on a collection and returns a cursor object.
db.collection.findAndModify() (page 38) Atomically modies and returns a single document.
db.collection.findOne() (page 42) Performs a query and returns a single document.
db.collection.getIndexStats() (page 44) Renders a human-readable view of the data collected by indexStats (page 347) which reects B-tree utilization.
db.collection.getIndexes() (page 45) Returns an array of documents that describe the existing indexes on a collection.
db.collection.getShardDistribution() (page 45) For collections in sharded clusters, db.collection.getShardDistribution() (page 45) reports data of chunk distribution.
db.collection.getShardVersion() (page 47) Internal diagnostic method for shard cluster.
db.collection.group() (page 47) Provides simple data aggregation function. Groups documents in a collection by a key, and processes the results. Use aggregate() (page 22) for more complex data aggregation.
db.collection.indexStats() (page 51) Renders a human-readable view of the data collected by indexStats (page 347) which reects B-tree utilization.
db.collection.initializeOrderedBulkOp() (page 51) Initializes a Bulk() (page 135) operations builder for an ordered list of operations.
db.collection.initializeUnorderedBulkOp() (page 52) Initializes a Bulk() (page 135) operations builder for an unordered list of operations.
db.collection.insert() (page 53) Creates a new document in a collection.
db.collection.isCapped() (page 56) Reports if a collection is a capped collection.
Continued on next page
21
MongoDB Reference Manual, Release 2.6.4
Table 2.1 continued from previous page
Name Description
db.collection.mapReduce() (page 56) Performs map-reduce style data aggregation.
db.collection.reIndex() (page 63) Rebuilds all existing indexes on a collection.
db.collection.remove() (page 64) Deletes documents from a collection.
db.collection.renameCollection() (page 67) Changes the name of a collection.
db.collection.save() (page 68) Provides a wrapper around an insert() (page 53) and update() (page 70) to insert new documents.
db.collection.stats() (page 69) Reports on the state of a collection. Provides a wrapper around the collStats (page 338).
db.collection.storageSize() (page 70) Reports the total size used by the collection in bytes. Provides a wrapper around the storageSize (page 339) eld of the collStats (page 338) output.
db.collection.totalIndexSize() (page 70) Reports the total size used by the indexes on a collection. Provides a wrapper around the totalIndexSize (page 339) eld of the collStats (page 338) output.
db.collection.totalSize() (page 70) Reports the total size of a collection, including the size of all documents and all indexes on a collection.
db.collection.update() (page 70) Modies a document in a collection.
db.collection.validate() (page 78) Performs diagnostic operations on a collection.
db.collection.aggregate()
New in version 2.2.
Denition
db.collection.aggregate(pipeline, options)
Calculates aggregate values for the data in a collection.
param array pipeline A sequence of data aggregation operations or stages. See the aggregation
pipeline operators (page 458) for details.
Changed in version 2.6: The method can still accept the pipeline stages as separate arguments
instead of as elements in an array; however, if you do not specify the pipeline as an array,
you cannot specify the options parameter.
param document options Additional options that aggregate() (page 22) passes to the
aggregate (page 208) command.
New in version 2.6: Available only if you specify the pipeline as an array.
The options document can contain the following elds and values:
eld boolean explain Species to return the information on the processing of the pipeline. See
Return Information on Aggregation Pipeline Operation (page 24) for an example.
New in version 2.6.
eld boolean allowDiskUse Enables writing to temporary les. When set to true, aggregation
operations can write data to the _tmp subdirectory in the dbPath directory. See Perform
Large Sort Operation with External Sort (page 24) for an example.
New in version 2.6.
eld document cursor Species the initial batch size for the cursor. The value of the cursor eld
is a document with the eld batchSize. See Specify an Initial Batch Size (page 24) for syntax
and example.
New in version 2.6.
Returns
A cursor to the documents produced by the nal stage of the aggregation pipeline operation, or
if you include the explain option, the document that provides details on the processing of the
aggregation operation.
22 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
If the pipeline includes the $out (page 465) operator, aggregate() (page 22) returns an
empty cursor. See $out (page 465) for more information.
Changed in version 2.6: The db.collection.aggregate() (page 22) method returns a
cursor and can return result sets of any size. Previous versions returned all results in a single
document, and the result set was subject to a size limit of 16 megabytes.
Changed in version 2.4: If an error occurs, the aggregate() (page 22) helper throws an exception. In previous
versions, the helper returned a document with the error message and code, and ok status eld not equal to 1, same as
the aggregate (page 208) command.
See also:
For more information, see http://docs.mongodb.org/manualcore/aggregation-pipeline, Aggre-
gation Reference (page 536), http://docs.mongodb.org/manualcore/aggregation-pipeline-limits,
and aggregate (page 208).
Cursor Behavior In the mongo (page 580) shell, if the cursor returned from the
db.collection.aggregate() (page 22) is not assigned to a variable using the var key-
word, then the mongo (page 580) shell automatically iterates the cursor up to 20 times. See
http://docs.mongodb.org/manualcore/cursors for cursor behavior in the mongo (page 580)
shell and http://docs.mongodb.org/manualtutorial/iterate-a-cursor for handling cursors in
the mongo (page 580) shell.
Cursors returned from aggregation only supports cursor methods that operate on evaluated cursors (i.e. cursors whose
rst batch has been retrieved), such as the following methods:
cursor.hasNext() (page 88)
cursor.next() (page 93)
cursor.toArray() (page 100)
cursor.forEach() (page 88)
cursor.map() (page 89)
cursor.objsLeftInBatch() (page 94)
cursor.itcount()
cursor.pretty()
Examples The examples in this section use the db.collection.aggregate() (page 22) helper provided in
the 2.6 version of the mongo (page 580) shell.
The following examples use the collection orders that contains the following documents:
{ _id: 1, cust_id: "abc1", ord_date: ISODate("2012-11-02T17:04:11.102Z"), status: "A", amount: 50 }
{ _id: 2, cust_id: "xyz1", ord_date: ISODate("2013-10-01T17:04:11.102Z"), status: "A", amount: 100 }
{ _id: 3, cust_id: "xyz1", ord_date: ISODate("2013-10-12T17:04:11.102Z"), status: "D", amount: 25 }
{ _id: 4, cust_id: "xyz1", ord_date: ISODate("2013-10-11T17:04:11.102Z"), status: "D", amount: 125 }
{ _id: 5, cust_id: "abc1", ord_date: ISODate("2013-11-12T17:04:11.102Z"), status: "A", amount: 25 }
Group by and Calculate a Sum The following aggregation operation selects documents with status equal to "A",
groups the matching documents by the cust_id eld and calculates the total for each cust_id eld from the
sum of the amount eld, and sorts the results by the total eld in descending order:
db.orders.aggregate([
{ $match: { status: "A" } },
{ $group: { _id: "$cust_id", total: { $sum: "$amount" } } },
{ $sort: { total: -1 } }
])
2.1. mongo Shell Methods 23
MongoDB Reference Manual, Release 2.6.4
The operation returns a cursor with the following documents:
{ "_id" : "xyz1", "total" : 100 }
{ "_id" : "abc1", "total" : 75 }
The mongo (page 580) shell iterates the returned cursor automatically to print the results. See
http://docs.mongodb.org/manualtutorial/iterate-a-cursor for handling cursors manually in
the mongo (page 580) shell.
Return Information on Aggregation Pipeline Operation The following aggregation operation sets the option
explain to true to return information about the aggregation operation.
db.orders.aggregate(
[
{ $match: { status: "A" } },
{ $group: { _id: "$cust_id", total: { $sum: "$amount" } } },
{ $sort: { total: -1 } }
],
{
explain: true
}
)
The operation returns a cursor with the document that contains detailed information regarding the processing of the
aggregation pipeline. For example, the document may show, among other details, which index, if any, the operation
used.
1
If the orders collection is a sharded collection, the document would also show the division of labor between
the shards and the merge operation, and for targeted queries, the targeted shards.
Note: The intended readers of the explain output document are humans, and not machines, and the output format
is subject to change between releases.
The mongo (page 580) shell iterates the returned cursor automatically to print the results. See
http://docs.mongodb.org/manualtutorial/iterate-a-cursor for handling cursors manually in
the mongo (page 580) shell.
Perform Large Sort Operation with External Sort Aggregation pipeline stages have maximum memory use limit.
To handle large datasets, set allowDiskUse option to true to enable writing data to temporary les, as in the
following example:
var results = db.stocks.aggregate(
[
{ $project : { cusip: 1, date: 1, price: 1, _id: 0 } },
{ $sort : { cusip : 1, date: 1 } }
],
{
allowDiskUse: true
}
)
Specify an Initial Batch Size To specify an initial batch size for the cursor, use the following syntax for the cursor
option:
1
index-lters can affect the choice of index used. See index-lters for details.
24 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
cursor: { batchSize: <int> }
For example, the following aggregation operation species the initial batch size of 0 for the cursor:
db.orders.aggregate(
[
{ $match: { status: "A" } },
{ $group: { _id: "$cust_id", total: { $sum: "$amount" } } },
{ $sort: { total: -1 } },
{ $limit: 2 }
],
{
cursor: { batchSize: 0 }
}
)
A batchSize of 0 means an empty rst batch and is useful for quickly returning a cursor or failure message without
doing signicant server-side work. Specify subsequent batch sizes to OP_GET_MORE
2
operations as with other
MongoDB cursors.
The mongo (page 580) shell iterates the returned cursor automatically to print the results. See
http://docs.mongodb.org/manualtutorial/iterate-a-cursor for handling cursors manually in
the mongo (page 580) shell.
db.collection.copyTo()
Denition
db.collection.copyTo(newCollection)
Copies all documents from collection into newCollection using server-side JavaScript. If
newCollection does not exist, MongoDB creates it.
If authorization is enabled, you must have access to all actions on all resources in order to run
db.collection.copyTo() (page 25). Providing such access is not recommended, but if your organi-
zation requires a user to run db.collection.copyTo() (page 25), create a role that grants anyAction
on resource-anyresource. Do not assign this role to any other user.
param string newCollection The name of the collection to write data to.
Warning: When using db.collection.copyTo() (page 25) check eld types to ensure that the
operation does not remove type information from documents during the translation from BSON to JSON.
Consider using cloneCollection() (page 103) to maintain type delity.
The db.collection.copyTo() (page 25) method uses the eval (page 235) command internally. As
a result, the db.collection.copyTo() (page 25) operation takes a global lock that blocks all other
read and write operations until the db.collection.copyTo() (page 25) completes.
copyTo() (page 25) returns the number of documents copied. If the copy fails, it throws an exception.
Behavior Because copyTo() (page 25) uses eval (page 235) internally, the copy operations will block all other
operations on the mongod (page 555) instance.
Example The following operation copies all documents from the source collection into the target collection.
2
http://docs.mongodb.org/meta-driver/latest/legacy/mongodb-wire-protocol/#wire-op-get-more
2.1. mongo Shell Methods 25
MongoDB Reference Manual, Release 2.6.4
db.source.copyTo(target)
db.collection.count()
Denition
db.collection.count(<query>)
Returns the count of documents that would match a find() (page 33) query. The
db.collection.count() (page 26) method does not perform the find() (page 33) operation but
instead counts and returns the number of results that match a query.
The db.collection.count() (page 26) method has the following parameter:
param document query The query selection criteria.
The db.collection.count() (page 26) method is equivalent to the
db.collection.find(<query>).count() construct.
See also:
cursor.count() (page 81)
Behavior
Sharded Clusters On a sharded cluster, db.collection.count() (page 26) can result in an inaccurate count
if orphaned documents exist or if a chunk migration is in progress.
To avoid these situations, on a sharded cluster, use the $group (page 460) stage of the
db.collection.aggregate() (page 22) method to $sum (page 527) the documents. For example, the
following operation counts the documents in a collection:
db.collection.aggregate(
[
{ $group: { _id: null, count: { $sum: 1 } } }
]
)
To get a count of documents that match a query condition, include the $match (page 464) stage as well:
db.collection.aggregate(
[
{ $match: <query condition> },
{ $group: { _id: null, count: { $sum: 1 } } }
]
)
See Perform a Count (page 465) for an example.
Index Use Consider a collection with the following index:
{ a: 1, b: 1 }
When performing a count, MongoDB can return the count using only the index if:
the query can use an index,
the query only contains conditions on the keys of the index, and
the query predicates access a single contiguous range of index keys.
26 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
For example, the following operations can return the count using only the index:
db.collection.find( { a: 5, b: 5 } ).count()
db.collection.find( { a: { $gt: 5 } } ).count()
db.collection.find( { a: 5, b: { $gt: 10 } } ).count()
If, however, the query can use an index but the query predicates do not access a single contiguous range of index keys
or the query also contains conditions on elds outside the index, then in addition to using the index, MongoDB must
also read the documents to return the count.
db.collection.find( { a: 5, b: { $in: [ 1, 2, 3 ] } } ).count()
db.collection.find( { a: { $gt: 5 }, b: 5 } ).count()
db.collection.find( { a: 5, b: 5, c: 5 } ).count()
In such cases, during the initial read of the documents, MongoDB pages the documents into memory such that subse-
quent calls of the same count operation will have better performance.
Examples
Count all Documents in a Collection To count the number of all documents in the orders collection, use the
following operation:
db.orders.count()
This operation is equivalent to the following:
db.orders.find().count()
Count all Documents that Match a Query Count the number of the documents in the orders collection with the
eld ord_dt greater than new Date(01/01/2012):
db.orders.count( { ord_dt: { $gt: new Date('01/01/2012') } } )
The query is equivalent to the following:
db.orders.find( { ord_dt: { $gt: new Date('01/01/2012') } } ).count()
db.collection.createIndex()
Denition
db.collection.createIndex(keys, options)
Deprecated since version 1.8.
Creates indexes on collections.
param document keys For each eld to index, a key-value pair with the eld and the index order:
1 for ascending or -1 for descending.
param document options One or more key-value pairs that specify index options. For a list of
options, see db.collection.ensureIndex() (page 30).
See also:
http://docs.mongodb.org/manualindexes, db.collection.createIndex() (page 27),
db.collection.dropIndex() (page 29), db.collection.dropIndexes() (page 30),
db.collection.getIndexes() (page 45), db.collection.reIndex() (page 63), and
db.collection.totalIndexSize() (page 70)
2.1. mongo Shell Methods 27
MongoDB Reference Manual, Release 2.6.4
db.collection.dataSize()
db.collection.dataSize()
Returns The size of the collection. This method provides a wrapper around the size (page 338)
output of the collStats (page 338) (i.e. db.collection.stats() (page 69)) com-
mand.
db.collection.distinct()
Denition
db.collection.distinct(eld, query)
Finds the distinct values for a specied eld across a single collection and returns the results in an array.
param string eld The eld for which to return distinct values.
param document query A query that species the documents from which to retrieve the distinct
values.
The db.collection.distinct() (page 28) method provides a wrapper around the distinct
(page 213) command. Results must not be larger than the maximum BSON size (page 658).
When possible to use covered indexes, the db.collection.distinct() (page 28) method will use an
index to nd the documents in the query as well as to return the data.
Examples The following are examples of the db.collection.distinct() (page 28) method:
Return an array of the distinct values of the eld ord_dt from all documents in the orders collection:
db.orders.distinct( 'ord_dt' )
Return an array of the distinct values of the eld sku in the subdocument item from all documents in the
orders collection:
db.orders.distinct( 'item.sku' )
Return an array of the distinct values of the eld ord_dt from the documents in the orders collection where
the price is greater than 10:
db.orders.distinct( 'ord_dt', { price: { $gt: 10 } } )
db.collection.drop()
db.collection.drop()
Call the db.collection.drop() (page 28) method on a collection to drop it from the database. The
method provides a wrapper around the drop (page 327) command.
db.collection.drop() (page 28) takes no arguments and will produce an error if called with any argu-
ments.
This method also removes any indexes associated with the dropped collection.
Warning: This method obtains a write lock on the affected database and will block other operations until it
has completed.
28 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.dropIndex()
Denition
db.collection.dropIndex(index)
Drops or removes the specied index from a collection. The db.collection.dropIndex() (page 29)
method provides a wrapper around the dropIndexes (page 327) command.
Note: You cannot drop the default index on the _id eld.
The db.collection.dropIndex() (page 29) method takes the following parameter:
param string,document index Species the index to drop. You can specify the index either by the
index name or by the index specication document.
3
To drop a text index, specify the index name.
To get the index name or the index specication document for the db.collection.dropIndex()
(page 29) method, use the db.collection.getIndexes() (page 45) method.
Example Consider a pets collection. Calling the getIndexes() (page 45) method on the pets collection
returns the following indexes:
[
{ "v" : 1,
"key" : { "_id" : 1 },
"ns" : "test.pets",
"name" : "_id_"
},
{
"v" : 1,
"key" : { "cat" : -1 },
"ns" : "test.pets",
"name" : "catIdx"
},
{
"v" : 1,
"key" : { "cat" : 1, "dog" : -1 },
"ns" : "test.pets",
"name" : "cat_1_dog_-1"
}
]
The single eld index on the eld cat has the user-specied name of catIdx
4
and the index specication document
of { "cat" : -1 }.
To drop the index catIdx, you can use either the index name:
db.pets.dropIndex( "catIdx" )
Or you can use the index specication document { "cat" : -1 }:
db.pets.dropIndex( { "cat" : -1 } )
3
When using a mongo (page 580) shell version earlier than 2.2.2, if you specied a name during the index creation, you must use the name to
drop the index.
4
During index creation, if the user does not specify an index name, the system generates the name by concatenating the index key eld and
value with an underscore, e.g. cat_1.
2.1. mongo Shell Methods 29
MongoDB Reference Manual, Release 2.6.4
db.collection.dropIndexes()
db.collection.dropIndexes()
Drops all indexes other than the required index on the _id eld. Only call dropIndexes() (page 30) as a
method on a collection object.
db.collection.ensureIndex()
Denition
db.collection.ensureIndex(keys, options)
Creates an index on the specied eld if the index does not already exist.
The ensureIndex() (page 30) method has the following elds:
param document keys A document that contains the eld and value pairs where the eld is the
index key and the value describes the type of index for that eld. For an ascending index on a
eld, specify a value of 1; for descending index, specify a value of -1.
MongoDB supports several different index types including text, geospatial, and hashed
indexes. See index-type-list for more information.
param document options A document that contains a set of options that controls the creation of the
index. See Options (page 30) for details.
Options The options document contains a set of options that controls the creation of the index. Different index
types can have additional options specic for that type.
Options for All Index Types The following options are available for all index types unless otherwise specied:
param Boolean background Builds the index in the background so that building an index does not block
other database activities. Specify true to build in the background. The default value is false.
param Boolean unique Creates a unique index so that the collection will not accept insertion of docu-
ments where the index key or keys match an existing value in the index. Specify true to create a
unique index. The default value is false.
The option is unavailable for hashed indexes.
param string name The name of the index. If unspecied, MongoDB generates an index name by con-
catenating the names of the indexed elds and the sort order.
Whether user specied or MongoDB generated, index names including their full namespace (i.e.
database.collection) cannot be longer than the Index Name Limit (page 659).
param Boolean dropDups Creates a unique index on a eld that may have duplicates. MongoDB in-
dexes only the rst occurrence of a key and removes all documents from the collection that contain
subsequent occurrences of that key. Specify true to create unique index. The default value is
false.
The option is unavailable for hashed indexes.
Deprecated since version 2.6.
Warning: dropDups will delete data from your collection when building the index.
30 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
param Boolean sparse If true, the index only references documents with the specied eld. These in-
dexes use less space but behave differently in some situations (particularly sorts). The default value
is false. See http://docs.mongodb.org/manualcore/index-sparse for more in-
formation.
Changed in version 2.6: 2dsphere indexes are sparse by default and ignore this option. For a
compound index that includes 2dsphere index key(s) along with keys of other types, only the
2dsphere index elds determine whether the index references a document.
2d, geoHaystack, and text indexes behave similarly to the 2dsphere indexes.
param integer expireAfterSeconds Species a value, in seconds, as a TTL to
control how long MongoDB retains documents in this collection. See
http://docs.mongodb.org/manualtutorial/expire-data for more informa-
tion on this functionality. This applies only to TTL indexes.
param index version v The index version number. The default index version depends on the version
of mongod (page 555) running when creating the index. Before version 2.0, the this value was 0;
versions 2.0 and later use version 1, which provides a smaller and faster index format. Specify a
different index version only in unusual situations.
Options for text Indexes The following options are available for text indexes only:
param document weights For text indexes, a document that contains eld and
weight pairs. The weight is an integer ranging from 1 to 99,999 and de-
notes the signicance of the eld relative to the other indexed elds in terms of
the score. You can specify weights for some or all the indexed elds. See
http://docs.mongodb.org/manualtutorial/control-results-of-text-search
to adjust the scores. The default value is 1.
param string default_language For text indexes, the language that deter-
mines the list of stop words and the rules for the stemmer and to-
kenizer. See text-search-languages for the available languages and
http://docs.mongodb.org/manualtutorial/specify-language-for-text-index
for more information and examples. The default value is english.
param string language_override For text indexes, the name of the eld, in the collections docu-
ments, that contains the override language for the document. The default value is language. See
specify-language-eld-text-index-example for an example.
param integer textIndexVersion For text indexes, the text index version number. Version can be
either 1 or 2.
In MongoDB 2.6, the default version is 2. MongoDB 2.4 can only support version 1.
New in version 2.6.
Options for 2dsphere Indexes The following option is available for 2dsphere indexes only:
param integer 2dsphereIndexVersion For 2dsphere indexes, the 2dsphere index version number.
Version can be either 1 or 2.
In MongoDB 2.6, the default version is 2. MongoDB 2.4 can only support version 1.
New in version 2.6.
Options for 2d Indexes The following options are available for 2d indexes only:
2.1. mongo Shell Methods 31
MongoDB Reference Manual, Release 2.6.4
param integer bits For 2d indexes, the number of precision of the stored geohash value of the location
data.
The bits value ranges from 1 to 32 inclusive. The default value is 26.
param number min For 2d indexes, the lower inclusive boundary for the longitude and latitude values.
The default value is -180.0.
param number max For 2d indexes, the upper inclusive boundary for the longitude and latitude values.
The default value is 180.0.
Options for geoHaystack Indexes The following option is available for geoHaystack indexes only:
param number bucketSize For geoHaystack indexes, specify the number of units within which to
group the location values; i.e. group in the same bucket those location values that are within the
specied number of units to each other.
The value must be greater than 0.
Behaviors The ensureIndex() (page 30) method has the behaviors described here.
To add or change index options you must drop the index using the dropIndex() (page 29) method and issue
another ensureIndex() (page 30) operation with the new options.
If you create an index with one set of options, and then issue the ensureIndex() (page 30) method with the
same index elds and different options without rst dropping the index, ensureIndex() (page 30) will not
rebuild the existing index with the new options.
If you call multiple ensureIndex() (page 30) methods with the same index specication at the same time,
only the rst operation will succeed, all other operations will have no effect.
Non-background indexing operations will block all other operations on a database.
MongoDB will not create an index (page 30) on a collection if the index entry for an existing document
exceeds the Maximum Index Key Length. Previous versions of MongoDB would create the index but not
index such documents.
Changed in version 2.6.
Examples
Create an Ascending Index on a Single Field The following example creates an ascending index on the eld
orderDate.
db.collection.ensureIndex( { orderDate: 1 } )
If the keys document species more than one eld, then ensureIndex() (page 30) creates a compound index.
Create an Index on a Multiple Fields The following example creates a compound index on the orderDate eld
(in ascending order) and the zipcode eld (in descending order.)
db.collection.ensureIndex( { orderDate: 1, zipcode: -1 } )
A compound index cannot include a hashed index component.
Note: The order of an index is important for supporting sort() (page 96) operations using the index.
See also:
32 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The http://docs.mongodb.org/manualindexes section of this manual for full documentation of
indexes and indexing in MongoDB.
http://docs.mongodb.org/manualcore/index-text for details on creating text indexes.
index-feature-geospatial and index-geohaystack-index for geospatial queries.
index-feature-ttl for expiration of data.
db.collection.getIndexes() (page 45) to view the specications of existing indexes for a collection.
db.collection.nd()
Denition
db.collection.find(<criteria>, <projection>)
Selects documents in a collection and returns a cursor to the selected documents.
5
param document criteria Species selection criteria using query operators (page 386). To return
all documents in a collection, omit this parameter or pass an empty document ({}).
param document projection Species the elds to return using projection operators (page 422).
To return all elds in the matching document, omit this parameter.
Returns
A cursor to the documents that match the query criteria. When the find() (page 33) method
returns documents, the method is actually returning a cursor to the documents.
If the projection argument is specied, the matching documents contain only the
projection elds and the _id eld. You can optionally exclude the _id eld.
Executing find() (page 33) directly in the mongo (page 580) shell automatically iterates the
cursor to display up to the rst 20 documents. Type it to continue iteration.
To access the returned documents with a driver, use the appropriate cursor handling mechanism
for the driver language.
The projection parameter takes a document of the following form:
{ field1: <boolean>, field2: <boolean> ... }
The <boolean> value can be any of the following:
1 or true to include the eld. The find() (page 33) method always includes the _id eld even if the eld is
not explicitly stated to return in the projection parameter.
0 or false to exclude the eld.
A projection cannot contain both include and exclude specications, except for the exclusion of the _id eld. In
projections that explicitly include elds, the _id eld is the only eld that you can explicitly exclude.
Examples
Find All Documents in a Collection The find() (page 33) method with no parameters returns all documents
from a collection and returns all elds for the documents. For example, the following operation returns all documents
in the bios collection:
5
db.collection.find() (page 33) is a wrapper for the more formal query structure that uses the $query (page 532) operator.
2.1. mongo Shell Methods 33
MongoDB Reference Manual, Release 2.6.4
db.bios.find()
Find Documents that Match Query Criteria To nd documents that match a set of selection criteria, call find()
with the <criteria> parameter. The following operation returns all the documents from the collection products
where qty is greater than 25:
db.products.find( { qty: { $gt: 25 } } )
Query for Equality The following operation returns documents in the bios collection where _id equals 5:
db.bios.find( { _id: 5 } )
Query Using Operators The following operation returns documents in the bios collection where _id equals
either 5 or ObjectId("507c35dd8fada716c89d0013"):
db.bios.find(
{
_id: { $in: [ 5, ObjectId("507c35dd8fada716c89d0013") ] }
}
)
Query for Ranges Combine comparison operators to specify ranges. The following operation returns documents
with field between value1 and value2:
db.collection.find( { field: { $gt: value1, $lt: value2 } } );
Query a Field that Contains an Array If a eld contains an array and your query has multiple conditional operators,
the eld as a whole will match if either a single array element meets the conditions or a combination of array elements
meet the conditions.
Given a collection students that contains the following documents:
{ "_id" : 1, "score" : [ -1, 3 ] }
{ "_id" : 2, "score" : [ 1, 5 ] }
{ "_id" : 3, "score" : [ 5, 5 ] }
The following query:
db.students.find( { score: { $gt: 0, $lt: 2 } } )
Matches the following documents:
{ "_id" : 1, "score" : [ -1, 3 ] }
{ "_id" : 2, "score" : [ 1, 5 ] }
In the document with _id equal to 1, the score: [ -1, 3 ] meets the conditions because the element -1
meets the $lt: 2 condition and the element 3 meets the $gt: 0 condition.
In the document with _id equal to 2, the score: [ 1, 5 ] meets the conditions because the element 1 meets
both the $lt: 2 condition and the $gt: 0 condition.
Query Arrays
34 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Query for an Array Element The following operation returns documents in the bios collection where the
array eld contribs contains the element "UNIX":
db.bios.find( { contribs: "UNIX" } )
Query an Array of Documents The following operation returns documents in the bios collection where
awards array contains a subdocument element that contains the award eld equal to "Turing Award" and the
year eld greater than 1980:
db.bios.find(
{
awards: {
$elemMatch: {
award: "Turing Award",
year: { $gt: 1980 }
}
}
}
)
Query Subdocuments
Query Exact Matches on Subdocuments The following operation returns documents in the bios collection
where the subdocument name is exactly { first: "Yukihiro", last: "Matsumoto" }, including the
order:
db.bios.find(
{
name: {
first: "Yukihiro",
last: "Matsumoto"
}
}
)
The name eld must match the sub-document exactly. The query does not match documents with the following name
elds:
{
first: "Yukihiro",
aka: "Matz",
last: "Matsumoto"
}
{
last: "Matsumoto",
first: "Yukihiro"
}
Query Fields of a Subdocument The following operation returns documents in the bios collection where
the subdocument name contains a eld first with the value "Yukihiro" and a eld last with the value
"Matsumoto". The query uses dot notation to access elds in a subdocument:
2.1. mongo Shell Methods 35
MongoDB Reference Manual, Release 2.6.4
db.bios.find(
{
"name.first": "Yukihiro",
"name.last": "Matsumoto"
}
)
The query matches the document where the name eld contains a subdocument with the eld first with the value
"Yukihiro" and a eld last with the value "Matsumoto". For instance, the query would match documents
with name elds that held either of the following values:
{
first: "Yukihiro",
aka: "Matz",
last: "Matsumoto"
}
{
last: "Matsumoto",
first: "Yukihiro"
}
Projections The projection parameter species which elds to return. The parameter contains either include or
exclude specications, not both, unless the exclude is for the _id eld.
Specify the Fields to Return The following operation returns all the documents from the products collection
where qty is greater than 25 and returns only the _id, item and qty elds:
db.products.find( { qty: { $gt: 25 } }, { item: 1, qty: 1 } )
The operation returns the following:
{ "_id" : 11, "item" : "pencil", "qty" : 50 }
{ "_id" : ObjectId("50634d86be4617f17bb159cd"), "item" : "bottle", "qty" : 30 }
{ "_id" : ObjectId("50634dbcbe4617f17bb159d0"), "item" : "paper", "qty" : 100 }
The following operation nds all documents in the bios collection and returns only the name eld, contribs
eld and _id eld:
db.bios.find( { }, { name: 1, contribs: 1 } )
Explicitly Excluded Fields The following operation queries the bios collection and returns all elds except
the first eld in the name subdocument and the birth eld:
db.bios.find(
{ contribs: 'OOP' },
{ 'name.first': 0, birth: 0 }
)
Explicitly Exclude the _id Field The following operation excludes the _id and qty elds from the result set:
db.products.find( { qty: { $gt: 25 } }, { _id: 0, qty: 0 } )
The documents in the result set contain all elds except the _id and qty elds:
36 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "item" : "pencil", "type" : "no.2" }
{ "item" : "bottle", "type" : "blue" }
{ "item" : "paper" }
The following operation nds documents in the bios collection and returns only the name eld and the
contribs eld:
db.bios.find(
{ },
{ name: 1, contribs: 1, _id: 0 }
)
On Arrays and Subdocuments The following operation queries the bios collection and returns the last
eld in the name subdocument and the rst two elements in the contribs array:
db.bios.find(
{ },
{
_id: 0,
'name.last': 1,
contribs: { $slice: 2 }
}
)
Iterate the Returned Cursor The find() (page 33) method returns a cursor to the results. In the mongo
(page 580) shell, if the returned cursor is not assigned to a variable using the var keyword, the cursor is auto-
matically iterated up to 20 times to access up to the rst 20 documents that match the query. You can use the
DBQuery.shellBatchSize to change the number of iterations. See Flags (page 80) and cursor-behaviors. To
iterate manually, assign the returned cursor to a variable using the var keyword.
With Variable Name The following example uses the variable myCursor to iterate over the cursor and print the
matching documents:
var myCursor = db.bios.find( );
myCursor
With next() Method The following example uses the cursor method next() (page 93) to access the documents:
var myCursor = db.bios.find( );
var myDocument = myCursor.hasNext() ? myCursor.next() : null;
if (myDocument) {
var myName = myDocument.name;
print (tojson(myName));
}
To print, you can also use the printjson() method instead of print(tojson()):
if (myDocument) {
var myName = myDocument.name;
printjson(myName);
}
2.1. mongo Shell Methods 37
MongoDB Reference Manual, Release 2.6.4
With forEach() Method The following example uses the cursor method forEach() (page 88) to iterate the
cursor and access the documents:
var myCursor = db.bios.find( );
myCursor.forEach(printjson);
Modify the Cursor Behavior The mongo (page 580) shell and the drivers provide several cursor methods that
call on the cursor returned by the find() (page 33) method to modify its behavior.
Order Documents in the Result Set The sort() (page 96) method orders the documents in the result set. The
following operation returns documents in the bios collection sorted in ascending order by the name eld:
db.bios.find().sort( { name: 1 } )
sort() (page 96) corresponds to the ORDER BY statement in SQL.
Limit the Number of Documents to Return The limit() (page 89) method limits the number of documents in
the result set. The following operation returns at most 5 documents in the bios collection:
db.bios.find().limit( 5 )
limit() (page 89) corresponds to the LIMIT statement in SQL.
Set the Starting Point of the Result Set The skip() (page 95) method controls the starting point of the results set.
The following operation skips the rst 5 documents in the bios collection and returns all remaining documents:
db.bios.find().skip( 5 )
Combine Cursor Methods The following example chains cursor methods:
db.bios.find().sort( { name: 1 } ).limit( 5 )
db.bios.find().limit( 5 ).sort( { name: 1 } )
Regardless of the order you chain the limit() (page 89) and the sort() (page 96), the request to the server has
the structure that treats the query and the sort() (page 96) modier as a single object. Therefore, the limit()
(page 89) operation method is always applied after the sort() (page 96) regardless of the specied order of the
operations in the chain. See the meta query operators (page 528).
db.collection.ndAndModify()
Denition
db.collection.findAndModify(<document>)
Modies and returns a single document. By default, the returned document does not include the modications
made on the update. To return the document with the modications made on the update, use the new option. The
findAndModify() (page 38) method is a shell helper around the findAndModify (page 237) command.
The findAndModify() (page 38) method has the following form:
db.collection.findAndModify({
query: <document>,
sort: <document>,
remove: <boolean>,
38 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
update: <document>,
new: <boolean>,
fields: <document>,
upsert: <boolean>
});
The db.collection.findAndModify() (page 38) method takes a document parameter with the follow-
ing subdocument elds:
param document query The selection criteria for the modication. The query eld employs the
same query selectors (page 386) as used in the db.collection.find() (page 33) method.
Although the query may match multiple documents, findAndModify() (page 38) will select
only one document to modify.
param document sort Determines which document the operation modies if the query selects mul-
tiple documents. findAndModify() (page 38) modies the rst document in the sort order
specied by this argument.
param Boolean remove Must specify either the remove or the update eld. Removes the doc-
ument specied in the query eld. Set this to true to remove the selected document . The
default is false.
param document update Must specify either the remove or the update eld. Performs an up-
date of the selected document. The update eld employs the same update operators (page 429)
or field: value specications to modify the selected document.
param Boolean new When true, returns the modied document rather than the original. The
findAndModify() (page 38) method ignores the new option for remove operations. The
default is false.
param document elds A subset of elds to return. The fields document species an inclusion
of a eld with 1, as in: fields: { <field1>: 1, <field2>: 1, ... }. See
projection.
param Boolean upsert Used in conjunction with the update eld.
When true, findAndModify() (page 38) creates a new document if no document matches
the query, or if documents match the query, findAndModify() (page 38) performs an
update.
The default is false.
Return Data The findAndModify() (page 38) method returns either: the pre-modication document or, if
new: true is set, the modied document.
Note:
If the query nds no document for update or remove operations, findAndModify() (page 38) returns
null.
If the query nds no document for an update with an upsert operation, findAndModify() (page 38)
creates a new document. If new is false, and the sort option is NOT specied, the method returns null.
If the query nds no document for an update with an upsert operation, findAndModify() (page 38)
creates a new document. If new is false, and a sort option, the method returns an empty document {}.
Behaviors
2.1. mongo Shell Methods 39
MongoDB Reference Manual, Release 2.6.4
Upsert and Unique Index When findAndModify() (page 38) includes the upsert: true option and the
query eld(s) is not uniquely indexed, the method could insert a document multiple times in certain circumstances.
For instance, if multiple clients each invoke the method with the same query condition and these methods complete
the find phase before any of methods perform the modify phase, these methods could result in the insertion of the
same document.
In the following example, no document with the name Andy exists, and multiple clients issue the following command:
db.people.findAndModify({
query: { name: "Andy" },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true
})
Then, if these clients findAndModify() (page 38) methods nish the query phase before any command starts
the modify phase, and there is no unique index on the name eld, the commands may all perform an upsert. To
prevent this condition, create a unique index on the name eld. With the unique index in place, the multiple methods
would observe one of the following behaviors:
Exactly one findAndModify() (page 38) would successfully insert a new document.
Zero or more findAndModify() (page 38) methods would update the newly inserted document.
Zero or more findAndModify() (page 38) methods would fail when they attempted to insert a duplicate. If
the method fails due to a unique index constraint violation, you can retry the method. Absent a delete of the
document, the retry should not fail.
Sharded Collections When using findAndModify (page 237) in a sharded environment, the query must con-
tain the shard key for all operations against the shard cluster for the sharded collections.
findAndModify (page 237) operations issued against mongos (page 571) instances for non-sharded collections
function normally.
Comparisons with the update Method When updating a document, findAndModify() (page 38) and the
update() (page 70) method operate differently:
By default, both operations modify a single document. However, the update() (page 70) method with its
multi option can modify more than one document.
If multiple documents match the update criteria, for findAndModify() (page 38), you can specify a sort
to provide some measure of control on which document to update.
With the default behavior of the update() (page 70) method, you cannot specify which single document to
update when multiple documents match.
By default, findAndModify() (page 38) method returns the pre-modied version of the document. To obtain
the updated document, use the new option.
The update() (page 70) method returns a WriteResult (page 198) object that contains the status of the
operation. To return the updated document, use the find() (page 33) method. However, other updates may
have modied the document between your update and the document retrieval. Also, if the update modied only
a single document but multiple documents matched, you will need to use additional logic to identify the updated
document.
You cannot specify a write concern to findAndModify() (page 38) to override the default write con-
cern whereas, starting in MongoDB 2.6, you can specify a write concern to the update() (page 70) method.
When modifying a single document, both findAndModify() (page 38) and
the update() (page 70) method atomically update the document. See
40 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
http://docs.mongodb.org/manualtutorial/isolate-sequence-of-operations for more
details about interactions and order of operations of these methods.
Examples
Update and Return The following method updates and returns an existing document in the people collection where
the document matches the query criteria:
db.people.findAndModify({
query: { name: "Tom", state: "active", rating: { $gt: 10 } },
sort: { rating: 1 },
update: { $inc: { score: 1 } }
})
This method performs the following actions:
1. The query nds a document in the people collection where the name eld has the value Tom, the state
eld has the value active and the rating eld has a value greater than (page 386) 10.
2. The sort orders the results of the query in ascending order. If multiple documents meet the query condition,
the method will select for modication the rst document as ordered by this sort.
3. The update increments the value of the score eld by 1.
4. The method returns the original (i.e. pre-modication) document selected for this update:
{
"_id" : ObjectId("50f1e2c99beb36a0f45c6453"),
"name" : "Tom",
"state" : "active",
"rating" : 100,
"score" : 5
}
To return the modied document, add the new:true option to the method.
If no document matched the query condition, the method returns null:
null
Upsert The following method includes the upsert: true option for the update operation to either update a
matching document or, if no matching document exists, create a new document:
db.people.findAndModify({
query: { name: "Gus", state: "active", rating: 100 },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true
})
If the method nds a matching document, the method performs an update.
If the method does not nd a matching document, the method creates a new document. Because the method included
the sort option, it returns an empty document { } as the original (pre-modication) document:
{ }
If the method did not include a sort option, the method returns null.
2.1. mongo Shell Methods 41
MongoDB Reference Manual, Release 2.6.4
null
Return New Document The following method includes both the upsert: true option and the new:true op-
tion. The method either updates a matching document and returns the updated document or, if no matching document
exists, inserts a document and returns the newly inserted document in the value eld.
In the following example, no document in the people collection matches the query condition:
db.people.findAndModify({
query: { name: "Pascal", state: "active", rating: 25 },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true,
new: true
})
The method returns the newly inserted document:
{
"_id" : ObjectId("50f49ad6444c11ac2448a5d6"),
"name" : "Pascal",
"rating" : 25,
"score" : 1,
"state" : "active"
}
Sort and Remove By including a sort specication on the rating eld, the following example removes from
the people collection a single document with the state value of active and the lowest rating among the
matching documents:
db.people.findAndModify(
{
query: { state: "active" },
sort: { rating: 1 },
remove: true
}
)
The method returns the deleted document:
{
"_id" : ObjectId("52fba867ab5fdca1299674ad"),
"name" : "XYZ123",
"score" : 1,
"state" : "active",
"rating" : 3
}
db.collection.ndOne()
Denition
db.collection.findOne(<criteria>, <projection>)
Returns one document that satises the specied query criteria. If multiple documents satisfy the query, this
method returns the rst document according to the natural order which reects the order of documents on the
disk. In capped collections, natural order is the same as insertion order.
42 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
param document criteria Species query selection criteria using query operators (page 386).
param document projection Species the elds to return using projection operators (page 422).
Omit this parameter to return all elds in the matching document.
The projection parameter takes a document of the following form:
{ field1: <boolean>, field2: <boolean> ... }
The <boolean> can be one of the following include or exclude values:
1 or true to include. The findOne() (page 42) method always includes the _id eld even if the eld is not
explicitly specied in the projection parameter.
0 or false to exclude.
The projection argument cannot mix include and exclude specications, with the exception of excluding the _id eld.
returns One document that satises the criteria specied as the rst argument to this method.
If you specify a projection parameter, findOne() (page 42) returns a document
that only contains the projection elds. The _id eld is always included unless you
explicitly exclude it.
Although similar to the find() (page 33) method, the findOne() (page 42) method
returns a document rather than a cursor.
Examples
With Empty Query Specication The following operation returns a single document from the bios
collection:
db.bios.findOne()
With a Query Specication The following operation returns the rst matching document from the bios
collection where either the eld first in the subdocument name starts with the letter G or where the eld
birth is less than new Date(01/01/1945):
db.bios.findOne(
{
$or: [
{ 'name.first' : /^G/ },
{ birth: { $lt: new Date('01/01/1945') } }
]
}
)
With a Projection The projection parameter species which elds to return. The parameter contains either
include or exclude specications, not both, unless the exclude is for the _id eld.
Specify the Fields to Return The following operation nds a document in the bios collection and returns
only the name, contribs and _id elds:
db.bios.findOne(
{ },
{ name: 1, contribs: 1 }
)
2.1. mongo Shell Methods 43
MongoDB Reference Manual, Release 2.6.4
Return All but the Excluded Fields The following operation returns a document in the bios collection
where the contribs eld contains the element OOP and returns all elds except the _id eld, the first eld in
the name subdocument, and the birth eld:
db.bios.findOne(
{ contribs: 'OOP' },
{ _id: 0, 'name.first': 0, birth: 0 }
)
The findOne Result Document You cannot apply cursor methods to the result of findOne() (page 42) because
a single document is returned. You have access to the document directly:
var myDocument = db.bios.findOne();
if (myDocument) {
var myName = myDocument.name;
print (tojson(myName));
}
db.collection.getIndexStats()
Denition
db.collection.getIndexStats(index)
Displays a human-readable summary of aggregated statistics about an indexs B-tree data structure. The in-
formation summarizes the output returned by the indexStats (page 347) command and indexStats()
(page 51) method. The getIndexStats() (page 44) method displays the information on the screen and does
not return an object.
The getIndexStats() (page 44) method has the following form:
db.<collection>.getIndexStats( { index : "<index name>" } )
param document index The index name.
The getIndexStats() (page 44) method is available only when connected to a mongod (page 555) instance
that uses the --enableExperimentalIndexStatsCmd option.
To view index names for a collection, use the getIndexes() (page 45) method.
Warning: Do not use getIndexStats() (page 44) or indexStats (page 347) with production
deployments.
Example The following command returns information for an index named type_1_traits_1:
db.animals.getIndexStats({index:"type_1_traits_1"})
The command returns the following summary. For more information on the B-tree statistics, see indexStats
(page 347).
-- index "undefined" --
version 1 | key pattern { "type" : 1, "traits" : 1 } | storage namespace "test.animals.$type_1_traits_1"
2 deep, bucket body is 8154 bytes
44 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
bucket count 45513 on average 99.401 % (0.463 %) full 49.581 % (4.135 %) bson keys, 49.820 % (4.275 %) key nodes
-- depth 0 --
bucket count 1 on average 71.511 % (0.000 %) full 36.191 % (0.000 %) bson keys, 35.320 % (0.000 %) key nodes
-- depth 1 --
bucket count 180 on average 98.954 % (5.874 %) full 49.732 % (5.072 %) bson keys, 49.221 % (5.161 %) key nodes
-- depth 2 --
bucket count 45332 on average 99.403 % (0.245 %) full 49.580 % (4.130 %) bson keys, 49.823 % (4.270 %) key nodes
db.collection.getIndexes()
db.collection.getIndexes()
Returns an array that holds a list of documents that identify and describe the existing indexes on the collection.
You must call the db.collection.getIndexes() (page 45) on a collection. For example:
db.collection.getIndexes()
Change collection to the name of the collection whose indexes you want to learn.
The db.collection.getIndexes() (page 45) items consist of the following elds:
system.indexes.v
Holds the version of the index.
The index version depends on the version of mongod (page 555) that created the index. Before version
2.0 of MongoDB, the this value was 0; versions 2.0 and later use version 1.
system.indexes.key
Contains a document holding the keys held in the index, and the order of the index. Indexes may be either
descending or ascending order. A value of negative one (e.g. -1) indicates an index sorted in descending
order while a positive value (e.g. 1) indicates an index sorted in an ascending order.
system.indexes.ns
The namespace context for the index.
system.indexes.name
A unique name for the index comprised of the eld names and orders of all keys.
db.collection.getShardDistribution()
Denition
db.collection.getShardDistribution()
Returns
Prints the data distribution statistics for a sharded collection. You must call the
getShardDistribution() (page 45) method on a sharded collection, as in the follow-
ing example:
db.myShardedCollection.getShardDistribution()
In the following example, the collection has two shards. The output displays both the individual shard distribu-
tion information as well the total shard distribution:
2.1. mongo Shell Methods 45
MongoDB Reference Manual, Release 2.6.4
Shard <shard-a> at <host-a>
data : <size-a> docs : <count-a> chunks : <number of chunks-a>
estimated data per chunk : <size-a>/<number of chunks-a>
estimated docs per chunk : <count-a>/<number of chunks-a>
Shard <shard-b> at <host-b>
data : <size-b> docs : <count-b> chunks : <number of chunks-b>
estimated data per chunk : <size-b>/<number of chunks-b>
estimated docs per chunk : <count-b>/<number of chunks-b>
Totals
data : <stats.size> docs : <stats.count> chunks : <calc total chunks>
Shard <shard-a> contains <estDataPercent-a>% data, <estDocPercent-a>% docs in cluster, avg obj size on shard : stats.shards[ <shard-a> ].avgObjSize
Shard <shard-b> contains <estDataPercent-b>% data, <estDocPercent-b>% docs in cluster, avg obj size on shard : stats.shards[ <shard-b> ].avgObjSize
See also:
http://docs.mongodb.org/manualsharding
Output The output information displays:
<shard-x> is a string that holds the shard name.
<host-x> is a string that holds the host name(s).
<size-x> is a number that includes the size of the data, including the unit of measure (e.g. b, Mb).
<count-x> is a number that reports the number of documents in the shard.
<number of chunks-x> is a number that reports the number of chunks in the shard.
<size-x>/<number of chunks-x> is a calculated value that reects the estimated data size per chunk
for the shard, including the unit of measure (e.g. b, Mb).
<count-x>/<number of chunks-x> is a calculated value that reects the estimated number of docu-
ments per chunk for the shard.
<stats.size> is a value that reports the total size of the data in the sharded collection, including the unit of
measure.
<stats.count> is a value that reports the total number of documents in the sharded collection.
<calc total chunks> is a calculated number that reports the number of chunks from all shards, for ex-
ample:
<calc total chunks> = <number of chunks-a> + <number of chunks-b>
<estDataPercent-x> is a calculated value that reects, for each shard, the data size as the percentage of
the collections total data size, for example:
<estDataPercent-x> = <size-x>/<stats.size>
<estDocPercent-x> is a calculated value that reects, for each shard, the number of documents as the
percentage of the total number of documents for the collection, for example:
<estDocPercent-x> = <count-x>/<stats.count>
stats.shards[ <shard-x> ].avgObjSize is a number that reects the average object size, including
the unit of measure, for the shard.
46 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example Output For example, the following is a sample output for the distribution of a sharded collection:
Shard shard-a at shard-a/MyMachine.local:30000,MyMachine.local:30001,MyMachine.local:30002
data : 38.14Mb docs : 1000003 chunks : 2
estimated data per chunk : 19.07Mb
estimated docs per chunk : 500001
Shard shard-b at shard-b/MyMachine.local:30100,MyMachine.local:30101,MyMachine.local:30102
data : 38.14Mb docs : 999999 chunks : 3
estimated data per chunk : 12.71Mb
estimated docs per chunk : 333333
Totals
data : 76.29Mb docs : 2000002 chunks : 5
Shard shard-a contains 50% data, 50% docs in cluster, avg obj size on shard : 40b
Shard shard-b contains 49.99% data, 49.99% docs in cluster, avg obj size on shard : 40b
db.collection.getShardVersion()
db.collection.getShardVersion()
This method returns information regarding the state of data in a sharded cluster that is useful when diagnosing
underlying issues with a sharded cluster.
For internal and diagnostic use only.
db.collection.group()
Recommended Alternatives
Because db.collection.group() (page 47) uses JavaScript, it is subject to a number of performance limi-
tations. For most cases the $group (page 460) operator in the aggregation pipeline provides a suitable
alternative with fewer restrictions.
Denition
db.collection.group({ key, reduce, initial, [keyf,] [cond,] nalize })
Groups documents in a collection by the specied keys and performs simple aggregation functions such as
computing counts and sums. The method is analogous to a SELECT <...> GROUP BY statement in SQL.
The group() (page 47) method returns an array.
The db.collection.group() (page 47) accepts a single document that contains the following:
eld document key The eld or elds to group. Returns a key object for use as the grouping key.
eld function reduce An aggregation function that operates on the documents during the grouping
operation. These functions may return a sum or a count. The function takes two arguments: the
current document and an aggregation result document for that group.
eld document initial Initializes the aggregation result document.
eld function keyf Alternative to the key eld. Species a function that creates a key object for
use as the grouping key. Use keyf instead of key to group by calculated elds rather than
existing document elds.
eld document cond The selection criteria to determine which documents in the collection to pro-
cess. If you omit the cond eld, db.collection.group() (page 47) processes all the
documents in the collection for the group operation.
2.1. mongo Shell Methods 47
MongoDB Reference Manual, Release 2.6.4
eld function nalize A function that runs each item in the result set before
db.collection.group() (page 47) returns the nal value. This function can either
modify the result document or replace the result document as a whole.
The db.collection.group() (page 47) method is a shell wrapper for the group (page 214) command.
However, the db.collection.group() (page 47) method takes the keyf eld and the reduce eld
whereas the group (page 214) command takes the $keyf eld and the $reduce eld.
Behavior
Limits and Restrictions The db.collection.group() (page 47) method does not work with sharded clusters.
Use the aggregation framework or map-reduce in sharded environments.
The result set must t within the maximum BSON document size (page 658).
In version 2.2, the returned array can contain at most 20,000 elements; i.e. at most 20,000 unique groupings. For group
by operations that results in more than 20,000 unique groupings, use mapReduce (page 218). Previous versions had
a limit of 10,000 elements.
Prior to 2.4, the db.collection.group() (page 47) method took the mongod (page 555) instances JavaScript
lock, which blocked all other JavaScript execution.
mongo Shell JavaScript Functions/Properties Changed in version 2.4: In MongoDB 2.4, map-reduce
operations (page 218), the group (page 214) command, and $where (page 404) operator expressions cannot
access certain global functions or properties, such as db, that are available in the mongo (page 580) shell.
When upgrading to MongoDB 2.4, you will need to refactor your code if your map-reduce operations
(page 218), group (page 214) commands, or $where (page 404) operator expressions include any global shell
functions or properties that are no longer available, such as db.
The following JavaScript functions and properties are available to map-reduce operations (page 218), the
group (page 214) command, and $where (page 404) operator expressions in MongoDB 2.4:
Available Properties Available Functions
args
MaxKey
MinKey
assert()
BinData()
DBPointer()
DBRef()
doassert()
emit()
gc()
HexData()
hex_md5()
isNumber()
isObject()
ISODate()
isString()
Map()
MD5()
NumberInt()
NumberLong()
ObjectId()
print()
printjson()
printjsononeline()
sleep()
Timestamp()
tojson()
tojsononeline()
tojsonObject()
UUID()
version()
48 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Examples The following examples assume an orders collection with documents of the following prototype:
{
_id: ObjectId("5085a95c8fada716c89d0021"),
ord_dt: ISODate("2012-07-01T04:00:00Z"),
ship_dt: ISODate("2012-07-02T04:00:00Z"),
item: { sku: "abc123",
price: 1.99,
uom: "pcs",
qty: 25 }
}
Group by Two Fields The following example groups by the ord_dt and item.sku elds those documents that
have ord_dt greater than 01/01/2011:
db.orders.group(
{
key: { ord_dt: 1, 'item.sku': 1 },
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
reduce: function ( curr, result ) { },
initial: { }
}
)
The result is an array of documents that contain the group by elds:
[
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc456"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "bcd123"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "efg456"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "efg456"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "ijk123"},
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc456"},
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc456"}
]
The method call is analogous to the SQL statement:
SELECT ord_dt, item_sku
FROM orders
WHERE ord_dt > '01/01/2012'
GROUP BY ord_dt, item_sku
Calculate the Sum The following example groups by the ord_dt and item.sku elds, those documents that
have ord_dt greater than 01/01/2011 and calculates the sum of the qty eld for each grouping:
db.orders.group(
{
key: { ord_dt: 1, 'item.sku': 1 },
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
reduce: function( curr, result ) {
result.total += curr.item.qty;
},
2.1. mongo Shell Methods 49
MongoDB Reference Manual, Release 2.6.4
initial: { total : 0 }
}
)
The result is an array of documents that contain the group by elds and the calculated aggregation eld:
[ { "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc456", "total" : 25 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "bcd123", "total" : 10 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "efg456", "total" : 10 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "efg456", "total" : 15 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "ijk123", "total" : 20 },
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc123", "total" : 45 },
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc456", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc456", "total" : 25 } ]
The method call is analogous to the SQL statement:
SELECT ord_dt, item_sku, SUM(item_qty) as total
FROM orders
WHERE ord_dt > '01/01/2012'
GROUP BY ord_dt, item_sku
Calculate Sum, Count, and Average The following example groups by the calculated day_of_week eld, those
documents that have ord_dt greater than 01/01/2011 and calculates the sum, count, and average of the qty eld
for each grouping:
db.orders.group(
{
keyf: function(doc) {
return { day_of_week: doc.ord_dt.getDay() };
},
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
reduce: function( curr, result ) {
result.total += curr.item.qty;
result.count++;
},
initial: { total : 0, count: 0 },
finalize: function(result) {
var weekdays = [
"Sunday", "Monday", "Tuesday",
"Wednesday", "Thursday",
"Friday", "Saturday"
];
result.day_of_week = weekdays[result.day_of_week];
result.avg = Math.round(result.total / result.count);
}
}
)
The result is an array of documents that contain the group by elds and the calculated aggregation eld:
[
{ "day_of_week" : "Sunday", "total" : 70, "count" : 4, "avg" : 18 },
{ "day_of_week" : "Friday", "total" : 110, "count" : 6, "avg" : 18 },
50 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "day_of_week" : "Tuesday", "total" : 70, "count" : 3, "avg" : 23 }
]
See also:
http://docs.mongodb.org/manualcore/aggregation
db.collection.indexStats()
Denition
db.collection.indexStats(index)
Aggregates statistics for the B-tree data structure that stores data for a MongoDB index. The
indexStats() (page 51) method is a thin wrapper around the indexStats (page 347) command. The
indexStats() (page 51) method is available only on mongod (page 555) instances running with the
--enableExperimentalIndexStatsCmd option.
Important: The indexStats() (page 51) method is not intended for production deployments.
The indexStats() (page 51) method has the following form:
db.<collection>.indexStats( { index: "<index name>" } )
The indexStats() (page 51) method has the following parameter:
param document index The index name.
The method takes a read lock and pages into memory all the extents, or B-tree buckets, encountered. The
method might be slow for large indexes if the underlying extents are not already in physical memory. Do not
run indexStats() (page 51) on a replica set primary. When run on a secondary, the command causes the
secondary to fall behind on replication.
The method aggregates statistics for the entire B-tree and for each individual level of the B-tree. For a description
of the commands output, see indexStats (page 347).
For more information about running indexStats() (page 51), see https://github.com/mongodb-labs/storage-
viz#readme.
db.collection.initializeOrderedBulkOp()
Denition
db.collection.initializeOrderedBulkOp()
Initializes and returns a new Bulk() (page 135) operations builder for a collection. The builder constructs an
ordered list of write operations that MongoDB executes in bulk.
Returns new Bulk() (page 135) operations builder object.
Behavior
Order of Operation With an ordered operations list, MongoDB executes the write operations in the list serially.
2.1. mongo Shell Methods 51
MongoDB Reference Manual, Release 2.6.4
Execution of Operations When executing an ordered (page 51) list of operations, MongoDB groups the opera-
tions by the operation type (page 146) and contiguity; i.e. contiguous operations of the same type are grouped
together. For example, if an ordered list has two insert operations followed by an update operation followed by an-
other insert operation, MongoDB groups the operations into three separate groups: rst group contains the two insert
operations, second group contains the update operation, and the third group contains the last insert operation. This
behavior is subject to change in future versions.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
Executing an ordered (page 51) list of operations on a sharded collection will generally be slower than executing an
unordered (page 52) list since with an ordered list, each operation must wait for the previous operation to nish.
Error Handling If an error occurs during the processing of one of the write operations, MongoDB will return
without processing any remaining write operations in the list.
Examples The following initializes a Bulk() (page 135) operations builder on the users collection, adds a series
of write operations, and executes the operations:
var bulk = db.users.initializeOrderedBulkOp();
bulk.insert( { user: "abc123", status: "A", points: 0 } );
bulk.insert( { user: "ijk123", status: "A", points: 0 } );
bulk.insert( { user: "mop123", status: "P", points: 0 } );
bulk.find( { status: "D" } ).remove();
bulk.find( { status: "P" } ).update( { $set: { comment: "Pending" } } );
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
Bulk.find() (page 138)
Bulk.find.removeOne() (page 139)
Bulk.execute() (page 136)
db.collection.initializeUnorderedBulkOp()
Denition
db.collection.initializeUnorderedBulkOp()
New in version 2.6.
Initializes and returns a new Bulk() (page 135) operations builder for a collection. The builder constructs an
unordered list of write operations that MongoDB executes in bulk.
Behavior
52 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Order of Operation With an unordered operations list, MongoDB can execute in parallel the write operations in the
list and in any order. If the order of operations matter, use db.collection.initializeOrderedBulkOp()
(page 51) instead.
Execution of Operations When executing an unordered (page 52) list of operations, MongoDB groups the op-
erations. With an unordered bulk operation, the operations in the list may be reordered to increase performance. As
such, applications should not depend on the ordering when performing unordered (page 52) bulk operations.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
Error Handling If an error occurs during the processing of one of the write operations, MongoDB will continue to
process remaining write operations in the list.
Example The following initializes a Bulk() (page 135) operations builder and adds a series of insert operations to
add multiple documents:
var bulk = db.users.initializeUnorderedBulkOp();
bulk.insert( { user: "abc123", status: "A", points: 0 } );
bulk.insert( { user: "ijk123", status: "A", points: 0 } );
bulk.insert( { user: "mop123", status: "P", points: 0 } );
bulk.execute();
See also:
db.collection.initializeOrderedBulkOp() (page 51)
Bulk() (page 135)
Bulk.insert() (page 146)
Bulk.execute() (page 136)
db.collection.insert()
Denition
db.collection.insert()
Inserts a document or documents into a collection.
The insert() (page 53) method has the following syntax:
Changed in version 2.6.
db.collection.insert(
<document or array of documents>,
{
writeConcern: <document>,
ordered: <boolean>
}
)
2.1. mongo Shell Methods 53
MongoDB Reference Manual, Release 2.6.4
param document,array document A document or array of documents to insert into the collection.
param document writeConcern A document expressing the write concern. Omit to use the
default write concern. See Safe Writes (page 54).
New in version 2.6.
param boolean ordered If true, perform an ordered insert of the documents in the array, and if
an error occurs with one of documents, MongoDB will return without processing the remaining
documents in the array. Defaults to false.
New in version 2.6.
Changed in version 2.6: The insert() (page 53) returns an object that contains the status of the operation.
Returns
A WriteResult (page 55) object for single inserts.
A BulkWriteResult (page 56) object for bulk inserts.
Behaviors
Safe Writes Changed in version 2.6.
The insert() (page 53) method uses the insert (page 245) command, which uses the default write concern. To
specify a different write concern, include the write concern in the options parameter.
Create Collection If the collection does not exist, then the insert() (page 53) method will create the collection.
_id Field If the document does not specify an _id eld, then MongoDB will add the _id eld and assign a
unique http://docs.mongodb.org/manualreference/object-id for the document before inserting.
Most drivers create an ObjectId and insert the _id eld, but the mongod (page 555) will create and populate the _id
if the driver or application does not.
If the document contains an _id eld, the _id value must be unique within the collection to avoid duplicate key error.
Examples The following examples insert documents into the products collection. If the collection does not exist,
the insert() (page 53) method creates the collection.
Insert a Document without Specifying an _id Field In the following example, the document passed to the
insert() (page 53) method does not contain the _id eld:
db.products.insert( { item: "card", qty: 15 } )
During the insert, mongod (page 555) will create the _id eld and assign it a unique
http://docs.mongodb.org/manualreference/object-id value, as veried by the inserted doc-
ument:
{ "_id" : ObjectId("5063114bd386d8fadbd6b004"), "item" : "card", "qty" : 15 }
The ObjectId values are specic to the machine and time when the operation is run. As such, your values may
differ from those in the example.
54 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Insert a Document Specifying an _id Field In the following example, the document passed to the insert()
(page 53) method includes the _id eld. The value of _id must be unique within the collection to avoid duplicate
key error.
db.products.insert( { _id: 10, item: "box", qty: 20 } )
The operation inserts the following document in the products collection:
{ "_id" : 10, "item" : "box", "qty" : 20 }
Insert Multiple Documents The following example performs a bulk insert of three documents by passing an array
of documents to the insert() (page 53) method.
The documents in the array do not need to have the same elds. For instance, the rst document in the array has an
_id eld and a type eld. Because the second and third documents do not contain an _id eld, mongod (page 555)
will create the _id eld for the second and third documents during the insert:
db.products.insert(
[
{ _id: 11, item: "pencil", qty: 50, type: "no.2" },
{ item: "pen", qty: 20 },
{ item: "eraser", qty: 25 }
]
)
The operation inserted the following three documents:
{ "_id" : 11, "item" : "pencil", "qty" : 50, "type" : "no.2" }
{ "_id" : ObjectId("51e0373c6f35bd826f47e9a0"), "item" : "pen", "qty" : 20 }
{ "_id" : ObjectId("51e0373c6f35bd826f47e9a1"), "item" : "eraser", "qty" : 25 }
Perform an Ordered Insert The following example performs an ordered insert of four documents. Unlike un-
ordered inserts which continue on error, ordered inserts return on error without processing the remaining documents
in the array.
db.products.insert(
[
{ _id: 20, item: "lamp", qty: 50, type: "desk" },
{ _id: 21, item: "lamp", qty: 20, type: "floor" },
{ _id: 22, item: "bulk", qty: 100 }
],
{ ordered: true }
)
Override Default Write Concern The following operation to a replica set species a write concern of "w:
majority" with a wtimeout of 5000 milliseconds such that the method returns after the write propagates to a
majority of the replica set members or the method times out after 5 seconds.
db.products.insert(
{ item: "envelopes", qty : 100, type: "Clasp" },
{ writeConcern: { w: "majority", wtimeout: 5000 } }
)
WriteResult Changed in version 2.6.
When passed a single document, insert() (page 53) returns a WriteResult object.
2.1. mongo Shell Methods 55
MongoDB Reference Manual, Release 2.6.4
Successful Results The insert() (page 53) returns a WriteResult (page 198) object that contains the status of
the operation. Upon success, the WriteResult (page 198) object contains information on the number of documents
inserted:
WriteResult({ "nInserted" : 1 })
Write Concern Errors If the insert() (page 53) method encounters write concern errors, the results include the
WriteResult.writeConcernError (page 199) eld:
WriteResult({
"nInserted" : 1,
"writeConcernError" : {
"code" : 64,
"errmsg" : "waiting for replication timed out at shard-a"
}
})
Errors Unrelated to Write Concern If the insert() (page 53) method encounters a non-write concern error, the
results include the WriteResult.writeError (page 199) eld:
WriteResult({
"nInserted" : 0,
"writeError" : {
"code" : 11000,
"errmsg" : "insertDocument :: caused by :: 11000 E11000 duplicate key error index: test.foo.$_id_ dup key: { : 1.0 }"
}
})
BulkWriteResult Changed in version 2.6.
When passed an array of documents, insert() (page 53) returns a BulkWriteResult() (page 196) object. See
BulkWriteResult() (page 196) for details.
db.collection.isCapped()
db.collection.isCapped()
Returns Returns true if the collection is a capped collection, otherwise returns false.
See also:
http://docs.mongodb.org/manualcore/capped-collections
db.collection.mapReduce()
db.collection.mapReduce(map, reduce, {<out>, <query>, <sort>, <limit>, <nalize>, <scope>,
<jsMode>, <verbose>})
The db.collection.mapReduce() (page 56) method provides a wrapper around the mapReduce
(page 218) command.
db.collection.mapReduce(
<map>,
<reduce>,
{
56 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
out: <collection>,
query: <document>,
sort: <document>,
limit: <number>,
finalize: <function>,
scope: <document>,
jsMode: <boolean>,
verbose: <boolean>
}
)
db.collection.mapReduce() (page 56) takes the following parameters:
eld Javascript function map AJavaScript function that associates or maps a value with a key
and emits the key and value pair.
See Requirements for the map Function (page 58) for more information.
eld JavaScript function reduce A JavaScript function that reduces to a single object all the
values associated with a particular key.
See Requirements for the reduce Function (page 59) for more information.
eld document options A document that species additional parameters to
db.collection.mapReduce() (page 56).
The following table describes additional arguments that db.collection.mapReduce() (page 56) can
accept.
eld string or document out Species the location of the result of the map-reduce operation. You
can output to a collection, output to a collection with an action, or output inline. You may output
to a collection when performing map reduce operations on the primary members of the set; on
secondary members you may only use the inline output.
See out Options (page 60) for more information.
eld document query Species the selection criteria using query operators (page 386) for deter-
mining the documents input to the map function.
eld document sort Sorts the input documents. This option is useful for optimization. For example,
specify the sort key to be the same as the emit key so that there are fewer reduce operations. The
sort key must be in an existing index for this collection.
eld number limit Species a maximum number of documents to return from the collection.
eld Javascript function nalize Follows the reduce method and modies the output.
See Requirements for the nalize Function (page 61) for more information.
eld document scope Species global variables that are accessible in the map, reduce and
finalize functions.
eld Boolean jsMode Species whether to convert intermediate data into BSON format between
the execution of the map and reduce functions. Defaults to false.
If false:
Internally, MongoDB converts the JavaScript objects emitted by the map function to BSON
objects. These BSON objects are then converted back to JavaScript objects when calling the
reduce function.
The map-reduce operation places the intermediate BSON objects in temporary, on-disk stor-
age. This allows the map-reduce operation to execute over arbitrarily large data sets.
2.1. mongo Shell Methods 57
MongoDB Reference Manual, Release 2.6.4
If true:
Internally, the JavaScript objects emitted during map function remain as JavaScript objects.
There is no need to convert the objects for the reduce function, which can result in faster
execution.
You can only use jsMode for result sets with fewer than 500,000 distinct key arguments
to the mappers emit() function.
The jsMode defaults to false.
eld Boolean verbose Species whether to include the timing information in the result informa-
tion. The verbose defaults to true to include the timing information.
Note: Changed in version 2.4.
In MongoDB 2.4, map-reduce operations (page 218), the group (page 214) command, and $where
(page 404) operator expressions cannot access certain global functions or properties, such as db, that are avail-
able in the mongo (page 580) shell.
When upgrading to MongoDB 2.4, you will need to refactor your code if your map-reduce operations
(page 218), group (page 214) commands, or $where (page 404) operator expressions include any global shell
functions or properties that are no longer available, such as db.
The following JavaScript functions and properties are available to map-reduce operations (page 218),
the group (page 214) command, and $where (page 404) operator expressions in MongoDB 2.4:
Available Properties Available Functions
args
MaxKey
MinKey
assert()
BinData()
DBPointer()
DBRef()
doassert()
emit()
gc()
HexData()
hex_md5()
isNumber()
isObject()
ISODate()
isString()
Map()
MD5()
NumberInt()
NumberLong()
ObjectId()
print()
printjson()
printjsononeline()
sleep()
Timestamp()
tojson()
tojsononeline()
tojsonObject()
UUID()
version()
Requirements for the map Function The map function has the following prototype:
function() {
...
emit(key, value);
}
The map function exhibits the following behaviors:
In the map function, reference the current document as this within the function.
58 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The map function should not access the database for any reason.
The map function should be pure, or have no impact outside of the function (i.e. side effects.)
The emit(key,value) function associates the key with a value.
A single emit can only hold half of MongoDBs maximum BSON document size (page 658).
The map function can call emit(key,value) any number of times, including 0, per each input docu-
ment.
The following map function may call emit(key,value) either 0 or 1 times depending on the value of
the input documents status eld:
function() {
if (this.status == 'A')
emit(this.cust_id, 1);
}
The following map function may call emit(key,value) multiple times depending on the number of
elements in the input documents items eld:
function() {
this.items.forEach(function(item){ emit(item.sku, 1); });
}
The map function can access the variables dened in the scope parameter.
Requirements for the reduce Function The reduce function has the following prototype:
function(key, values) {
...
return result;
}
The reduce function exhibits the following behaviors:
The reduce function should not access the database, even to perform read operations.
The reduce function should not affect the outside system.
MongoDB will not call the reduce function for a key that has only a single value. The values argument is
an array whose elements are the value objects that are mapped to the key.
MongoDB can invoke the reduce function more than once for the same key. In this case, the previous output
from the reduce function for that key will become one of the input values to the next reduce function
invocation for that key.
The reduce function can access the variables dened in the scope parameter.
Because it is possible to invoke the reduce function more than once for the same key, the following properties need
to be true:
the type of the return object must be identical to the type of the value emitted by the map function to ensure
that the following operations is true:
reduce(key, [ C, reduce(key, [ A, B ]) ] ) == reduce( key, [ C, A, B ] )
the reduce function must be idempotent. Ensure that the following statement is true:
reduce( key, [ reduce(key, valuesArray) ] ) == reduce( key, valuesArray )
2.1. mongo Shell Methods 59
MongoDB Reference Manual, Release 2.6.4
the order of the elements in the valuesArray should not affect the output of the reduce function, so that
the following statement is true:
reduce( key, [ A, B ] ) == reduce( key, [ B, A ] )
out Options You can specify the following options for the out parameter:
Output to a Collection
out: <collectionName>
Output to a Collection with an Action This option is only available when passing out a collection that already
exists. This option is not available on secondary members of replica sets.
out: { <action>: <collectionName>
[, db: <dbName>]
[, sharded: <boolean> ]
[, nonAtomic: <boolean> ] }
When you output to a collection with an action, the out has the following parameters:
<action>: Specify one of the following actions:
replace
Replace the contents of the <collectionName> if the collection with the <collectionName> ex-
ists.
merge
Merge the new result with the existing result if the output collection already exists. If an existing document
has the same key as the new result, overwrite that existing document.
reduce
Merge the new result with the existing result if the output collection already exists. If an existing document
has the same key as the new result, apply the reduce function to both the new and the existing documents
and overwrite the existing document with the result.
db:
Optional.The name of the database that you want the map-reduce operation to write its output. By default this
will be the same database as the input collection.
sharded:
Optional. If true and you have enabled sharding on output database, the map-reduce operation will shard the
output collection using the _id eld as the shard key.
nonAtomic:
New in version 2.2.
Optional. Specify output operation as non-atomic and is valid only for merge and reduce output modes
which may take minutes to execute.
If nonAtomic is true, the post-processing step will prevent MongoDB from locking the database; however,
other clients will be able to read intermediate states of the output collection. Otherwise the map reduce operation
must lock the database during post-processing.
60 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Output Inline Perform the map-reduce operation in memory and return the result. This option is the only available
option for out on secondary members of replica sets.
out: { inline: 1 }
The result must t within the maximum size of a BSON document (page 658).
Requirements for the finalize Function The finalize function has the following prototype:
function(key, reducedValue) {
...
return modifiedObject;
}
The finalize function receives as its arguments a key value and the reducedValue from the reduce function.
Be aware that:
The finalize function should not access the database for any reason.
The finalize function should be pure, or have no impact outside of the function (i.e. side effects.)
The finalize function can access the variables dened in the scope parameter.
Map-Reduce Examples Consider the following map-reduce operations on a collection orders that contains doc-
uments of the following prototype:
{
_id: ObjectId("50a8240b927d5d8b5891743c"),
cust_id: "abc123",
ord_date: new Date("Oct 04, 2012"),
status: 'A',
price: 25,
items: [ { sku: "mmm", qty: 5, price: 2.5 },
{ sku: "nnn", qty: 5, price: 2.5 } ]
}
Return the Total Price Per Customer Perform the map-reduce operation on the orders collection to group by
the cust_id, and calculate the sum of the price for each cust_id:
1. Dene the map function to process each input document:
In the function, this refers to the document that the map-reduce operation is processing.
The function maps the price to the cust_id for each document and emits the cust_id and price
pair.
var mapFunction1 = function() {
emit(this.cust_id, this.price);
};
2. Dene the corresponding reduce function with two arguments keyCustId and valuesPrices:
The valuesPrices is an array whose elements are the price values emitted by the map function and
grouped by keyCustId.
The function reduces the valuesPrice array to the sum of its elements.
var reduceFunction1 = function(keyCustId, valuesPrices) {
return Array.sum(valuesPrices);
};
2.1. mongo Shell Methods 61
MongoDB Reference Manual, Release 2.6.4
3. Perform the map-reduce on all documents in the orders collection using the mapFunction1 map function
and the reduceFunction1 reduce function.
db.orders.mapReduce(
mapFunction1,
reduceFunction1,
{ out: "map_reduce_example" }
)
This operation outputs the results to a collection named map_reduce_example. If the
map_reduce_example collection already exists, the operation will replace the contents with the re-
sults of this map-reduce operation:
Calculate Order and Total Quantity with Average Quantity Per Item In this example, you will perform a
map-reduce operation on the orders collection for all documents that have an ord_date value greater than
01/01/2012. The operation groups by the item.sku eld, and calculates the number of orders and the total
quantity ordered for each sku. The operation concludes by calculating the average quantity per order for each sku
value:
1. Dene the map function to process each input document:
In the function, this refers to the document that the map-reduce operation is processing.
For each item, the function associates the sku with a new object value that contains the count of 1
and the item qty for the order and emits the sku and value pair.
var mapFunction2 = function() {
for (var idx = 0; idx < this.items.length; idx++) {
var key = this.items[idx].sku;
var value = {
count: 1,
qty: this.items[idx].qty
};
emit(key, value);
}
};
2. Dene the corresponding reduce function with two arguments keySKU and countObjVals:
countObjVals is an array whose elements are the objects mapped to the grouped keySKU values
passed by map function to the reducer function.
The function reduces the countObjVals array to a single object reducedValue that contains the
count and the qty elds.
In reducedVal, the count eld contains the sum of the count elds from the individual array ele-
ments, and the qty eld contains the sum of the qty elds from the individual array elements.
var reduceFunction2 = function(keySKU, countObjVals) {
reducedVal = { count: 0, qty: 0 };
for (var idx = 0; idx < countObjVals.length; idx++) {
reducedVal.count += countObjVals[idx].count;
reducedVal.qty += countObjVals[idx].qty;
}
return reducedVal;
};
62 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
3. Dene a nalize function with two arguments key and reducedVal. The function modies the
reducedVal object to add a computed eld named avg and returns the modied object:
var finalizeFunction2 = function (key, reducedVal) {
reducedVal.avg = reducedVal.qty/reducedVal.count;
return reducedVal;
};
4. Perform the map-reduce operation on the orders collection using the mapFunction2,
reduceFunction2, and finalizeFunction2 functions.
db.orders.mapReduce( mapFunction2,
reduceFunction2,
{
out: { merge: "map_reduce_example" },
query: { ord_date:
{ $gt: new Date('01/01/2012') }
},
finalize: finalizeFunction2
}
)
This operation uses the query eld to select only those documents with ord_date greater than new
Date(01/01/2012). Then it output the results to a collection map_reduce_example. If the
map_reduce_example collection already exists, the operation will merge the existing contents with the
results of this map-reduce operation.
Output The output of the db.collection.mapReduce() (page 56) method is identical to that of the
mapReduce (page 218) command. See the Output (page 225) section of the mapReduce (page 218) command
for information on the db.collection.mapReduce() (page 56) output.
Additional Information
http://docs.mongodb.org/manualtutorial/troubleshoot-map-function
http://docs.mongodb.org/manualtutorial/troubleshoot-reduce-function
mapReduce (page 218) command
http://docs.mongodb.org/manualcore/aggregation
Map-Reduce
http://docs.mongodb.org/manualtutorial/perform-incremental-map-reduce
db.collection.reIndex()
db.collection.reIndex()
The db.collection.reIndex() (page 63) drops all indexes on a collection and recreates them. This
operation may be expensive for collections that have a large amount of data and/or a large number of indexes.
Call this method, which takes no arguments, on a collection object. For example:
db.collection.reIndex()
2.1. mongo Shell Methods 63
MongoDB Reference Manual, Release 2.6.4
Normally, MongoDB compacts indexes during routine updates. For most users, the
db.collection.reIndex() (page 63) is unnecessary. However, it may be worth running if the
collection size has changed signicantly or if the indexes are consuming a disproportionate amount of disk
space.
Behavior
Note: For replica sets, db.collection.reIndex() (page 63) will not propagate from the primary to secon-
daries. db.collection.reIndex() (page 63) will only affect a single mongod (page 555) instance.
Important: db.collection.reIndex() (page 63) will rebuild indexes in the background if the index was
originally specied with this option. However, db.collection.reIndex() (page 63) will rebuild the _id
index in the foreground, which takes the databases write lock.
Changed in version 2.6: Reindexing operations will error if the index entry for an indexed eld exceeds the Maximum
Index Key Length. Reindexing operations occur as part of compact (page 316) and repairDatabase
(page 332) commands as well as the db.collection.reIndex() (page 63) method.
Because these operations drop all the indexes from a collection and then recreate them sequentially, the error from the
Maximum Index Key Length prevents these operations fromrebuilding any remaining indexes for the collection
and, in the case of the repairDatabase (page 332) command, from continuing with the remainder of the process.
See
http://docs.mongodb.org/manualcore/index-creation for more information on the behavior of in-
dexing operations in MongoDB.
db.collection.remove()
Denition
db.collection.remove()
Removes documents from a collection.
The db.collection.remove() (page 64) method can have one of two syntaxes. The remove()
(page 64) method can take a query document and an optional justOne boolean:
db.collection.remove(
<query>,
<justOne>
)
Or the method can take a query document and an optional remove options document:
New in version 2.6.
db.collection.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)
param document query Species deletion criteria using query operators (page 386). To delete all
documents in a collection, pass an empty document ({}).
64 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Changed in version 2.6: In previous versions, the method invoked with no query parameter
deleted all documents in a collection.
param boolean justOne To limit the deletion to just one document, set to true. Omit to use the
default value of false and delete all documents matching the deletion criteria.
param document writeConcern A document expressing the write concern. Omit to use the
default write concern. See Safe Writes (page 65).
New in version 2.6.
Changed in version 2.6: The remove() (page 64) returns an object that contains the status of the operation.
Returns A WriteResult (page 66) object that contains the status of the operation.
Behavior
Safe Writes Changed in version 2.6.
The remove() (page 64) method uses the delete (page 232) command, which uses the default write concern. To
specify a different write concern, include the write concern in the options parameter.
Query Considerations By default, remove() (page 64) removes all documents that match the query expression.
Specify the justOne option to limit the operation to removing a single document. To delete a single document sorted
by a specied order, use the ndAndModify() (page 42) method.
When removing multiple documents, the remove operation may interleave with other read and/or write operations to
the collection. For unsharded collections, you can override this behavior with the $isolated (page 456) operator,
which isolates the remove operation and disallows yielding during the operation. This ensures that no client can see
the affected documents until they are all processed or an error stops the remove operation.
See Isolate Remove Operations (page 66) for an example.
Capped Collections You cannot use the remove() (page 64) method with a capped collection.
Sharded Collections All remove() (page 64) operations for a sharded collection that specify the justOne option
must include the shard key or the _id eld in the query specication. remove() (page 64) operations specifying
justOne in a sharded collection without the shard key or the _id eld return an error.
Examples The following are examples of the remove() (page 64) method.
Remove All Documents from a Collection To remove all documents in a collection, call the remove (page 64)
method with an empty query document {}. The following operation deletes all documents from the bios
collection:
db.bios.remove( { } )
This operation is not equivalent to the drop() (page 28) method.
To remove all documents from a collection, it may be more efcient to use the drop() (page 28) method to drop the
entire collection, including the indexes, and then recreate the collection and rebuild the indexes.
2.1. mongo Shell Methods 65
MongoDB Reference Manual, Release 2.6.4
Remove All Documents that Match a Condition To remove the documents that match a deletion criteria, call the
remove() (page 64) method with the <query> parameter:
The following operation removes all the documents from the collection products where qty is greater than 20:
db.products.remove( { qty: { $gt: 20 } } )
Override Default Write Concern The following operation to a replica set removes all the documents from the
collection products where qty is greater than 20 and species a write concern of "w: majority" with
a wtimeout of 5000 milliseconds such that the method returns after the write propagates to a majority of the replica
set members or the method times out after 5 seconds.
db.products.remove(
{ qty: { $gt: 20 } },
{ writeConcern: { w: "majority", wtimeout: 5000 } }
)
Remove a Single Document that Matches a Condition To remove the rst document that match a deletion criteria,
call the remove (page 64) method with the query criteria and the justOne parameter set to true or 1.
The following operation removes the rst document from the collection products where qty is greater than 20:
db.products.remove( { qty: { $gt: 20 } }, true )
Isolate Remove Operations To isolate the query, include $isolated: 1 in the <query> parameter as in the
following examples:
db.products.remove( { qty: { $gt: 20 }, $isolated: 1 } )
WriteResult Changed in version 2.6.
Successful Results The remove() (page 64) returns a WriteResult (page 198) object that contains the status of
the operation. Upon success, the WriteResult (page 198) object contains information on the number of documents
removed:
WriteResult({ "nRemoved" : 4 })
See also:
WriteResult.nRemoved (page 199)
Write Concern Errors If the remove() (page 64) method encounters write concern errors, the results include the
WriteResult.writeConcernError (page 199) eld:
WriteResult({
"nRemoved" : 21,
"writeConcernError" : {
"code" : 64,
"errInfo" : {
"wtimeout" : true
},
"errmsg" : "waiting for replication timed out"
}
})
66 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
See also:
WriteResult.hasWriteConcernError() (page 199)
Errors Unrelated to Write Concern If the remove() (page 64) method encounters a non-write concern error, the
results include WriteResult.writeError (page 199) eld:
WriteResult({
"nRemoved" : 0,
"writeError" : {
"code" : 2,
"errmsg" : "unknown top level operator: $invalidFieldName"
}
})
See also:
WriteResult.hasWriteError() (page 200)
db.collection.renameCollection()
Denition
db.collection.renameCollection(target, dropTarget)
Renames a collection. Provides a wrapper for the renameCollection (page 331) database command.
param string target The new name of the collection. Enclose the string in quotes.
param boolean dropTarget If true, mongod (page 555) drops the target of
renameCollection (page 331) prior to renaming the collection.
Example Call the db.collection.renameCollection() (page 67) method on a collection object. For
example:
db.rrecord.renameCollection("record")
This operation will rename the rrecord collection to record. If the target name (i.e. record) is the name of an
existing collection, then the operation will fail.
Limitations The method has the following limitations:
db.collection.renameCollection() (page 67) cannot move a collection between databases. Use
renameCollection (page 331) for these rename operations.
db.collection.renameCollection() (page 67) cannot operation on sharded collections.
The db.collection.renameCollection() (page 67) method operates within a collection by changing the
metadata associated with a given collection.
Refer to the documentation renameCollection (page 331) for additional warnings and messages.
Warning: The db.collection.renameCollection() (page 67) method and renameCollection
(page 331) command will invalidate open cursors which interrupts queries that are currently returning data.
2.1. mongo Shell Methods 67
MongoDB Reference Manual, Release 2.6.4
db.collection.save()
Denition
db.collection.save()
Updates an existing document or inserts a new document, depending on its document parameter.
The save() (page 68) method has the following form:
Changed in version 2.6.
db.collection.save(
<document>,
{
writeConcern: <document>
}
)
param document document A document to save to the collection.
param document writeConcern A document expressing the write concern. Omit to use the
default write concern. See Safe Writes (page 68).
New in version 2.6.
Changed in version 2.6: The save() (page 68) returns an object that contains the status of the operation.
Returns A WriteResult (page 69) object that contains the status of the operation.
Behavior
Safe Writes Changed in version 2.6.
The save() (page 68) method uses either the insert (page 245) or the update (page 249) command, which use
the default write concern. To specify a different write concern, include the write concern in the options parameter.
Insert If the document does not contain an _id eld, then the save() (page 68) method calls the
insert() (page 53) method. During the operation, the mongo (page 580) shell will create an
http://docs.mongodb.org/manualreference/object-id and assign it to the _id eld.
Note: Most MongoDB driver clients will include the _id eld and generate an ObjectId before sending the insert
operation to MongoDB; however, if the client sends a document without an _id eld, the mongod (page 555) will
add the _id eld and generate the ObjectId.
Update If the document contains an _id eld, then the save() (page 68) method is equivalent to an update with
the upsert option (page 72) set to true and the query predicate on the _id eld.
Examples
Save a New Document without Specifying an _id Field In the following example, save() (page 68) method
performs an insert since the document passed to the method does not contain the _id eld:
db.products.save( { item: "book", qty: 40 } )
68 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
During the insert, mongod (page 555) will create the _id eld with a unique
http://docs.mongodb.org/manualreference/object-id value, as veried by the inserted doc-
ument:
{ "_id" : ObjectId("50691737d386d8fadbd6b01d"), "item" : "book", "qty" : 40 }
The ObjectId values are specic to the machine and time when the operation is run. As such, your values may
differ from those in the example.
Save a New Document Specifying an _id Field In the following example, save() (page 68) performs an update
with upsert:true since the document contains an _id eld:
db.products.save( { _id: 100, item: "water", qty: 30 } )
Because the _id eld holds a value that does not exist in the collection, the update operation results in an insertion of
the document. The results of these operations are identical to an update() method with the upsert option (page 72) set
to true.
The operation results in the following new document in the products collection:
{ "_id" : 100, "item" : "water", "qty" : 30 }
Replace an Existing Document The products collection contains the following document:
{ "_id" : 100, "item" : "water", "qty" : 30 }
The save() (page 68) method performs an update with upsert:true since the document contains an _id eld:
db.products.save( { _id : 100, item : "juice" } )
Because the _id eld holds a value that exists in the collection, the operation performs an update to replace the
document and results in the following document:
{ "_id" : 100, "item" : "juice" }
Override Default Write Concern The following operation to a replica set species a write concern of "w:
majority" with a wtimeout of 5000 milliseconds such that the method returns after the write propagates to a
majority of the replica set members or the method times out after 5 seconds.
db.products.save(
{ item: "envelopes", qty : 100, type: "Clasp" },
{ writeConcern: { w: "majority", wtimeout: 5000 } }
)
WriteResult Changed in version 2.6.
The save() (page 68) returns a WriteResult (page 198) object that contains the status of the insert or update
operation. See WriteResult for insert (page 55) and WriteResult for update (page 77) for details.
db.collection.stats()
Denition
db.collection.stats(scale)
Returns statistics about the collection. The method includes the following parameter:
2.1. mongo Shell Methods 69
MongoDB Reference Manual, Release 2.6.4
param number scale The scale used in the output to display the sizes of items. By default, output
displays sizes in bytes. To display kilobytes rather than bytes, specify a scale value of 1024.
Returns A document containing statistics that reecting the state of the specied collection.
The stats() (page 69) method provides a wrapper around the database command collStats (page 338).
Example The following operation returns stats on the people collection:
db.people.stats()
See also:
collStats (page 338) for an overview of the output of this command.
db.collection.storageSize()
db.collection.storageSize()
Returns The total amount of storage allocated to this collection for document storage. Provides
a wrapper around the storageSize (page 339) eld of the collStats (page 338) (i.e.
db.collection.stats() (page 69)) output.
db.collection.totalIndexSize()
db.collection.totalIndexSize()
Returns The total size of all indexes for the collection. This method provides a wrapper
around the totalIndexSize (page 339) output of the collStats (page 338) (i.e.
db.collection.stats() (page 69)) operation.
db.collection.totalSize()
db.collection.totalSize()
Returns The total size of the data in the collection plus the size of every indexes on the collection.
db.collection.update()
Denition
db.collection.update(query, update, options)
Modies an existing document or documents in a collection. The method can modify specic elds of an
existing document or documents or replace an existing document entirely, depending on the update parameter
(page 71).
By default, the update() (page 70) method updates a single document. Set the Multi Parameter (page 73) to
update all documents that match the query criteria.
The update() (page 70) method has the following form:
Changed in version 2.6.
70 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
The update() (page 70) method takes the following parameters:
param document query The selection criteria for the update. Use the same query selectors
(page 386) as used in the find() (page 33) method.
param document update The modications to apply. For details see Update Parameter (page 71).
param boolean upsert If set to true, creates a new document when no document matches the
query criteria. The default value is false, which does not insert a new document when no
match is found.
param boolean multi If set to true, updates multiple documents that meet the query criteria. If
set to false, updates one document. The default value is false. For additional information,
see Multi Parameter (page 73).
param document writeConcern A document expressing the write concern. Omit to use the
default write concern. See Safe Writes (page 71).
New in version 2.6.
Changed in version 2.6: The update() (page 70) method returns an object that contains the status of the
operation.
Returns A WriteResult (page 77) object that contains the status of the operation.
Behavior
Safe Writes Changed in version 2.6.
The update() (page 70) method uses the update (page 249) command, which uses the default write concern. To
specify a different write concern, include the writeConcern option in the options parameter. See Override Default
Write Concern (page 75) for an example.
Update Parameter The update() (page 70) method either modies specic elds in existing documents or re-
places an existing document entirely.
Update Specic Fields If the <update> document contains update operator (page 429) modiers, such as those
using the $set (page 436) modier, then:
The <update> document must contain only update operator (page 429) expressions.
The update() (page 70) method updates only the corresponding elds in the document. For an example, see
Update Specic Fields (page 73).
2.1. mongo Shell Methods 71
MongoDB Reference Manual, Release 2.6.4
Replace a Document Entirely If the <update> document contains only field:value expressions, then:
The update() (page 70) method replaces the matching document with the <update> document. The
update() (page 70) method does not replace the _id value. For an example, see Replace All Fields (page 74).
update() (page 70) cannot update multiple documents (page 73).
Upsert Option
Upsert Behavior If upsert is true and no document matches the query criteria, update() (page 70) inserts a
single document. The update creates the new document with either:
The elds and values of the <update> parameter, or
The elds and values of both the <query> and <update> parameters if the <update> parameter contains
only update operator (page 429) expressions. The update creates a base document from the equality clauses in
the <query> parameter, and then applies the update expressions from the <update> parameter.
If upsert is true and there are documents that match the query criteria, update() (page 70) performs an update.
See also:
$setOnInsert (page 435)
Use Unique Indexes
Warning: To avoid inserting the same document more than once, only use upsert: true if the query eld
is uniquely indexed.
Given a collection named people where no documents have a name eld that holds the value Andy. Consider when
multiple clients issue the following update with upsert: true at the same time:
db.people.update(
{ name: "Andy" },
{
name: "Andy",
rating: 1,
score: 1
},
{ upsert: true }
)
If all update() (page 70) operations complete the query portion before any client successfully inserts data, and
there is no unique index on the name eld, then each update operation may result in an insert.
To prevent MongoDB from inserting the same document more than once, create a unique index on the name eld.
With a unique index, if multiple applications issue the same update with upsert: true, exactly one update()
(page 70) would successfully insert a new document.
The remaining operations would either:
update the newly inserted document, or
fail when they attempted to insert a duplicate.
If the operation fails because of a duplicate index key error, applications may retry the operation which will
succeed as an update operation.
72 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Multi Parameter If multi is set to true, the update() (page 70) method updates all documents that meet
the <query> criteria. The multi update operation may interleave with other operations, both read and/or write
operations. For unsharded collections, you can override this behavior with the $isolated (page 456) operator,
which isolates the update operation and disallows yielding during the operation. This isolates the update so that no
client can see the updated documents until they are all processed, or an error stops the update operation.
If the <update> (page 71) document contains only field:value expressions, then update() (page 70) cannot
update multiple documents.
For an example, see Update Multiple Documents (page 75).
Sharded Collections All update() (page 70) operations for a sharded collection that specify the multi:
false option must include the shard key or the _id eld in the query specication. update() (page 70) op-
erations specifying multi: false in a sharded collection without the shard key or the _id eld return an error.
See also:
findAndModify() (page 38)
Examples
Update Specic Fields To update specic elds in a document, use update operators (page 429) in the <update>
parameter. If the <update> parameter refers to non-existent elds in the current document, the update() (page 70)
method adds the elds to the document.
For example, given a books collection with the following document:
{ "_id" : 11, "item" : "Divine Comedy", "stock" : 2 }
The following operation adds a price eld to the document and increments the stock eld by 5.
db.books.update(
{ item: "Divine Comedy" },
{
$set: { price: 18 },
$inc: { stock: 5 }
}
)
The updated document is now the following:
{ "_id" : 11, "item" : "Divine Comedy", "price" : 18, "stock" : 7 }
See also:
$set (page 436), $inc (page 430), Update Operators (page 429)
Update Specic Fields in Embedded Documents Use dot notation to update specic elds in embedded docu-
ments.
For example, given a books collection with the following document:
{ _id: 50, item: "TDB", stock: 0, isbn: { group: 11, publisher: 1111, title: 11, digit: 1 } }
The following example updates the publisher eld and the digit eld in the isbn embedded document:
2.1. mongo Shell Methods 73
MongoDB Reference Manual, Release 2.6.4
db.books.update(
{ _id: 50 },
{ $set: { "isbn.publisher": 2222, "isbn.digit": 0 } }
)
Remove Fields The following operation uses the $unset (page 436) operator to remove the stock eld:
db.books.update( { _id: 11 }, { $unset: { stock: 1 } } )
See also:
$unset (page 436), $rename (page 434), Update Operators (page 429)
Replace All Fields Given the following document in the books collection:
{
"_id" : 22,
"item" : "The Banquet",
"author" : "Dante",
"price" : 20,
"stock" : 4
}
The following operation passes an <update> document that contains only eld and value pairs, which means the
document replaces all the elds in the original document. The operation does not replace the _id value. The operation
contains the same value for the item eld in both the <query> and <update> documents, which means the eld
does not change:
db.books.update(
{ item: "The Banquet" },
{ item: "The Banquet", price: 19 , stock: 3 }
)
The operation creates the following new document. The operation removed the author eld and changed the values
of the price and stock elds:
{
"_id" : 22,
"item" : "The Banquet",
"price" : 19,
"stock" : 3
}
Insert a New Document if No Match Exists The following update sets the upsert (page 72) option to true so
that update() (page 70) creates a new document in the books collection if no document matches the <query>
parameter:
db.books.update(
{ item: "The New Life" },
{ item: "The New Life", author: "Dante", price: 15 },
{ upsert: true }
)
If no document matches the <query> parameter, the update operation inserts a document with the elds and values
of the <update> parameter and a new unique ObjectId for the _id eld:
74 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
"_id" : ObjectId("51e5990c95098ed69d4a89f2"),
"author" : "Dante",
"item" : "The New Life",
"price" : 15
}
Update Multiple Documents To update multiple documents, set the multi option to true. For example, the
following operation updates all documents where stock is less than 5:
db.books.update(
{ stock: { $lt: 5 } },
{ $set: { reorder: true } },
{ multi: true }
)
Override Default Write Concern The following operation on a replica set species a write concern of "w:
majority" with a wtimeout of 5000 milliseconds such that the method returns after the write propagates to a
majority of the replica set members or the method times out after 5 seconds.
db.books.update(
{ stock: { $lt: 5 } },
{ $set: { reorder: true } },
{
multi: true,
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
Combine the upsert and multi Options Given a books collection that includes the following documents:
{ _id: 11, author: "Dante", item: "Divine Comedy", price: 18, translatedBy: "abc123" }
{ _id: 12, author: "Dante", item: "Divine Comedy", price: 21, translatedBy: "jkl123" }
{ _id: 13, author: "Dante", item: "Divine Comedy", price: 15, translatedBy: "xyz123" }
The following command species the multi parameter to update all documents where item is "Divine Comedy"
and the author is "Dante" and species upsert: true to create a new document if no matching documents
are found:
db.books.update(
{ item: "Divine Comedy", author: "Dante" },
{ $set: { reorder: false, price: 10 } },
{ upsert: true, multi: true }
)
The operation updates all three matching documents and results in the following:
{ _id: 11, author: "Dante", item: "Divine Comedy", price: 10, translatedBy: "abc123", reorder: false }
{ _id: 12, author: "Dante", item: "Divine Comedy", price: 10, translatedBy: "jkl123", reorder: false }
{ _id: 13, author: "Dante", item: "Divine Comedy", price: 10, translatedBy: "xyz123", reorder: false }
If the collection had no matching document, the operation would result in the insertion of a document:
{ _id: ObjectId("536aa66422363a21bc16bfd7"), author: "Dante", item: "Divine Comedy", reorder: false, price: 10 }
2.1. mongo Shell Methods 75
MongoDB Reference Manual, Release 2.6.4
Update Arrays
Update an Element by Position If the update operation requires an update of an element in an array eld, the
update() (page 70) method can perform the update using the position of the element and dot notation. Arrays in
MongoDB are zero-based.
The following operation queries the bios collection for the rst document with the _id eld equal to 1 and
updates the second element in the contribs array:
db.bios.update(
{ _id: 1 },
{ $set: { "contribs.1": "ALGOL 58" } }
)
Update an Element if Position is Unknown If the position in the array is not known, the update() (page 70)
method can perform the update using the $ positional operator. The array eld must appear in the <query> parameter
in order to determine which array element to update.
The following operation queries the bios collection for the rst document where the _id eld equals 3 and
the contribs array contains an element equal to compiler. If found, the update() (page 70) method updates
the rst matching element in the array to A compiler in the document:
db.bios.update(
{ _id: 3, "contribs": "compiler" },
{ $set: { "contribs.$": "A compiler" } }
)
Update a Document Element The update() (page 70) method can perform the update of an array that contains
embedded documents by using the positional operator (i.e. $) and the dot notation.
The following example queries the bios collection for the rst document where the _id eld equals 4 and the
awards array contains an embedded document where the by eld equals ACM. If found, the update() (page 70)
method updates the by eld in the rst matching embedded document:
db.bios.update(
{ _id: 4, "awards.by": "ACM" } ,
{ $set: { "awards.$.by": "Association for Computing Machinery" } }
)
Add an Element The following operation queries the bios collection for the rst document that has an _id
eld equal to 1 and adds a new element to the awards eld:
db.bios.update(
{ _id: 1 },
{
$push: { awards: { award: "IBM Fellow", year: 1963, by: "IBM" } }
}
)
In the next example, the $set (page 436) operator uses dot notation to access the middle eld in the name embed-
ded document. The $push (page 444) operator adds an embedded document to the awards array.
Consider the following operation:
76 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.bios.update(
{ _id: 1 },
{
$set: { "name.middle": "Warner" },
$push: { awards: {
award: "IBM Fellow",
year: "1963",
by: "IBM"
}
}
}
)
This update() (page 70) operation:
Modies the eld name whose value is another document. Specically, the $set (page 436) operator updates
the middle eld in the name document. The document uses dot notation to access a eld in an embedded
document.
Adds an element to the eld awards, whose value is an array. Specically, the $push (page 444) operator
adds another document as an element to the eld awards.
WriteResult Changed in version 2.6.
Successful Results The update() (page 70) method returns a WriteResult (page 198) object that contains the
status of the operation. Upon success, the WriteResult (page 198) object contains the number of documents that
matched the query condition, the number of documents inserted by the update, and the number of documents modied:
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
See
WriteResult.nMatched (page 199), WriteResult.nUpserted (page 199), WriteResult.nModified
(page 199)
Write Concern Errors If the update() (page 70) method encounters write concern errors, the results include the
WriteResult.writeConcernError (page 199) eld:
WriteResult({
"nMatched" : 1,
"nUpserted" : 0,
"nModified" : 1,
"writeConcernError" : {
"code" : 64,
"errmsg" : "waiting for replication timed out at shard-a"
}
})
See also:
WriteResult.hasWriteConcernError() (page 199)
Errors Unrelated to Write Concern If the update() (page 70) method encounters a non-write concern error, the
results include the WriteResult.writeError (page 199) eld:
2.1. mongo Shell Methods 77
MongoDB Reference Manual, Release 2.6.4
WriteResult({
"nMatched" : 0,
"nUpserted" : 0,
"nModified" : 0,
"writeError" : {
"code" : 7,
"errmsg" : "could not contact primary for replica set shard-a"
}
})
See also:
WriteResult.hasWriteError() (page 200)
db.collection.validate()
Description
db.collection.validate(full)
Validates a collection. The method scans a collections data structures for correctness and returns a single
document that describes the relationship between the logical collection and the physical representation of the
data.
The validate() (page 78) method has the following parameter:
param Boolean full Specify true to enable a full validation and to return full statistics. MongoDB
disables full validation by default because it is a potentially resource-intensive operation.
The validate() (page 78) method output provides an in-depth view of how the collection uses storage. Be
aware that this command is potentially resource intensive and may impact the performance of your MongoDB
instance.
The validate() (page 78) method is a wrapper around the validate (page 374) database command.
See also:
validate (page 374)
78 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
2.1.2 Cursor
Cursor Methods
Name Description
cursor.addOption()
(page 79)
Adds special wire protocol ags that modify the behavior of the query.
cursor.batchSize()
(page 80)
Controls the number of documents MongoDB will return to the client in a single
network message.
cursor.count()
(page 81)
Returns a count of the documents in a cursor.
cursor.explain()
(page 83)
Reports on the query execution plan, including index use, for a cursor.
cursor.forEach()
(page 88)
Applies a JavaScript function for every document in a cursor.
cursor.hasNext()
(page 88)
Returns true if the cursor has documents and can be iterated.
cursor.hint()
(page 88)
Forces MongoDB to use a specic index for a query.
cursor.limit()
(page 89)
Constrains the size of a cursors result set.
cursor.map()
(page 89)
Applies a function to each document in a cursor and collects the return values in an
array.
cursor.max()
(page 90)
Species an exclusive upper index bound for a cursor. For use with
cursor.hint() (page 88)
cursor.maxTimeMS()
(page 91)
Species a cumulative time limit in milliseconds for processing operations on a
cursor.
cursor.min()
(page 92)
Species an inclusive lower index bound for a cursor. For use with
cursor.hint() (page 88)
cursor.next()
(page 93)
Returns the next document in a cursor.
cursor.objsLeftInBatch()
(page 94)
Returns the number of documents left in the current cursor batch.
cursor.readPref()
(page 94)
Species a read preference to a cursor to control how the client directs queries to a
replica set.
cursor.showDiskLoc()
(page 94)
Returns a cursor with modied documents that include the on-disk location of the
document.
cursor.size()
(page 95)
Returns a count of the documents in the cursor after applying skip() (page 95) and
limit() (page 89) methods.
cursor.skip()
(page 95)
Returns a cursor that begins returning results only after passing or skipping a number
of documents.
cursor.snapshot()
(page 96)
Forces the cursor to use the index on the _id eld. Ensures that the cursor returns
each document, with regards to the value of the _id eld, only once.
cursor.sort()
(page 96)
Returns results ordered according to a sort specication.
cursor.toArray()
(page 100)
Returns an array that contains all documents returned by the cursor.
cursor.addOption()
Denition
cursor.addOption(ag)
Adds OP_QUERY wire protocol ags, such as the tailable ag, to change the behavior of queries.
2.1. mongo Shell Methods 79
MongoDB Reference Manual, Release 2.6.4
The cursor.addOption() (page 79) method has the following parameter:
param ag ag OP_QUERY wire protocol ag. See MongoDB wire protocol
6
for more informa-
tion on MongoDB Wire Protocols and the OP_QUERY ags. For the mongo (page 580)
shell, you can use cursor ags (page 80). For the driver-specic list, see your driver
documentation.
Flags The mongo (page 580) shell provides several additional cursor ags to modify the behavior of the cursor.
DBQuery.Option.tailable
DBQuery.Option.slaveOk
DBQuery.Option.oplogReplay
DBQuery.Option.noTimeout
DBQuery.Option.awaitData
DBQuery.Option.exhaust
DBQuery.Option.partial
For a description of the ags, see MongoDB wire protocol
7
.
Example The following example adds the DBQuery.Option.tailable ag and the
DBQuery.Option.awaitData ag to ensure that the query returns a tailable cursor. The sequence cre-
ates a cursor that will wait for few seconds after returning the full result set so that it can capture and return additional
data added during the query:
var t = db.myCappedCollection;
var cursor = t.find().addOption(DBQuery.Option.tailable).
addOption(DBQuery.Option.awaitData)
Warning: Adding incorrect wire protocol ags can cause problems and/or extra server load.
cursor.batchSize()
Denition
cursor.batchSize(size)
Species the number of documents to return in each batch of the response from the MongoDB instance. In most
cases, modifying the batch size will not affect the user or the application, as the mongo (page 580) shell and
most drivers return results as if MongoDB returned a single batch.
The batchSize() (page 80) method takes the following parameter:
param integer size The number of documents to return per batch. Do not use a batch size of 1.
Note: Specifying 1 or a negative number is analogous to using the limit() (page 89) method.
6
http://docs.mongodb.org/meta-driver/latest/legacy/mongodb-wire-protocol/?pageVersion=106#op-query
7
http://docs.mongodb.org/meta-driver/latest/legacy/mongodb-wire-protocol/?pageVersion=106#op-query
80 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example The following example sets the batch size for the results of a query (i.e. find() (page 33)) to 10. The
batchSize() (page 80) method does not change the output in the mongo (page 580) shell, which, by default,
iterates over the rst 20 documents.
db.inventory.find().batchSize(10)
cursor.count()
Denition
cursor.count()
Counts the number of documents referenced by a cursor. Append the count() (page 81) method to a find()
(page 33) query to return the number of matching documents. The operation does not perform the query but
instead counts the results that would be returned by the query.
Changed in version 2.6: MongoDB supports the use of hint() (page 88) with count() (page 81). See
Specify the Index to Use (page 82) for an example.
The count() (page 81) method has the following prototype form:
db.collection.find(<query>).count()
The count() (page 81) method has the following parameter:
param Boolean applySkipLimit Species whether to consider the effects of the
cursor.skip() (page 95) and cursor.limit() (page 89) methods in the count.
By default, the count() (page 81) method ignores the effects of the cursor.skip()
(page 95) and cursor.limit() (page 89). Set applySkipLimit to true to consider
the effect of these methods.
MongoDB also provides an equivalent db.collection.count() (page 26) as an alternative to the
db.collection.find(<query>).count() construct.
See also:
cursor.size() (page 95)
Behavior
Sharded Clusters On a sharded cluster, count() (page 81) method can result in an inaccurate count if orphaned
documents exist or if a chunk migration is in progress.
To avoid these situations, on a sharded cluster, use the $group (page 460) stage of the
db.collection.aggregate() (page 22) method to $sum (page 527) the documents. For example, the
following operation counts the documents in a collection:
db.collection.aggregate(
[
{ $group: { _id: null, count: { $sum: 1 } } }
]
)
To get a count of documents that match a query condition, include the $match (page 464) stage as well:
db.collection.aggregate(
[
{ $match: <query condition> },
{ $group: { _id: null, count: { $sum: 1 } } }
2.1. mongo Shell Methods 81
MongoDB Reference Manual, Release 2.6.4
]
)
See Perform a Count (page 465) for an example.
Index Use Consider a collection with the following index:
{ a: 1, b: 1 }
When performing a count, MongoDB can return the count using only the index if:
the query can use an index,
the query only contains conditions on the keys of the index, and
the query predicates access a single contiguous range of index keys.
For example, the following operations can return the count using only the index:
db.collection.find( { a: 5, b: 5 } ).count()
db.collection.find( { a: { $gt: 5 } } ).count()
db.collection.find( { a: 5, b: { $gt: 10 } } ).count()
If, however, the query can use an index but the query predicates do not access a single contiguous range of index keys
or the query also contains conditions on elds outside the index, then in addition to using the index, MongoDB must
also read the documents to return the count.
db.collection.find( { a: 5, b: { $in: [ 1, 2, 3 ] } } ).count()
db.collection.find( { a: { $gt: 5 }, b: 5 } ).count()
db.collection.find( { a: 5, b: 5, c: 5 } ).count()
In such cases, during the initial read of the documents, MongoDB pages the documents into memory such that subse-
quent calls of the same count operation will have better performance.
Examples The following are examples of the count() (page 81) method.
Count All Documents The following operation counts the number of all documents in the orders collection:
db.orders.find().count()
Count Documents That Match a Query The following operation counts the number of the documents in the
orders collection with the eld ord_dt greater than new Date(01/01/2012):
db.orders.find( { ord_dt: { $gt: new Date('01/01/2012') } } ).count()
Limit Documents in Count The following operation counts the number of the documents in the orders collection
with the eld ord_dt greater than new Date(01/01/2012) taking into account the effect of the limit(5):
db.orders.find( { ord_dt: { $gt: new Date('01/01/2012') } } ).limit(5).count(true)
Specify the Index to Use The following operation uses the index { status: 1 } to return a count of the
documents in the orders collection with the eld ord_dt greater than new Date(01/01/2012) and the
status eld is equal to "D":
82 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.orders.find(
{ ord_dt: { $gt: new Date('01/01/2012') }, status: "D" }
).hint( { status: 1 } ).count()
cursor.explain()
Denition
cursor.explain(verbose)
Provides information on the query plan. The query plan is the plan the server uses to nd the matches for a
query. This information may be useful when optimizing a query. The explain() (page 83) method returns a
document that describes the process used to return the query results.
The explain() (page 83) method has the following form:
db.collection.find().explain()
The explain() (page 83) method has the following parameter:
param Boolean verbose Species the level of detail to include in the output. If true or 1, includes
the allPlans and oldPlan elds in the output.
For an explanation of output, see Explain on Queries on Sharded Collections (page 84) and Core Explain Output
Fields (page 85).
Behavior The explain() (page 83) method runs the actual query to determine the result. Although there are some
differences between running the query with explain() (page 83) and running without, generally, the performance
will be similar between the two. So, if the query is slow, the explain() (page 83) operation is also slow.
Additionally, the explain() (page 83) operation reevaluates a set of candidate query plans, which may cause the
explain() (page 83) operation to perform differently than a normal query. As a result, these operations generally
provide an accurate account of how MongoDB would perform the query, but do not reect the length of these queries.
See also:
$explain (page 529)
http://docs.mongodb.org/manualadministration/optimization page for information re-
garding optimization strategies.
http://docs.mongodb.org/manualtutorial/manage-the-database-profiler tutorial
for information regarding the database prole.
Current Operation Reporting (page 107)
Explain Results
Explain on Queries on Unsharded Collections For queries on unsharded collections, explain() (page 83)
returns the following core information.
{
"cursor" : "<Cursor Type and Index>",
"isMultiKey" : <boolean>,
"n" : <num>,
"nscannedObjects" : <num>,
"nscanned" : <num>,
"nscannedObjectsAllPlans" : <num>,
2.1. mongo Shell Methods 83
MongoDB Reference Manual, Release 2.6.4
"nscannedAllPlans" : <num>,
"scanAndOrder" : <boolean>,
"indexOnly" : <boolean>,
"nYields" : <num>,
"nChunkSkips" : <num>,
"millis" : <num>,
"indexBounds" : { <index bounds> },
"allPlans" : [
{ "cursor" : "<Cursor Type and Index>",
"n" : <num>,
"nscannedObjects" : <num>,
"nscanned" : <num>,
"indexBounds" : { <index bounds> }
},
...
],
"oldPlan" : {
"cursor" : "<Cursor Type and Index>",
"indexBounds" : { <index bounds> }
}
"server" : "<host:port>",
"filterSet" : <boolean>
}
For details on the elds, see Core Explain Output Fields (page 85).
Explain on $or Queries Queries with the $or (page 393) operator can use separate indexes on each clause of the
$or (page 393) expression. If the query is indexed, explain() (page 83) contains output (page 85) for each clause
as well as the cumulative data for the entire query:
{
"clauses" : [
{
<core explain output>
},
{
<core explain output>
},
...
],
"n" : <num>,
"nscannedObjects" : <num>,
"nscanned" : <num>,
"nscannedObjectsAllPlans" : <num>,
"nscannedAllPlans" : <num>,
"millis" : <num>,
"server" : "<host:port>"
}
For details on the elds, see $or Query Output Fields (page 87) and Core Explain Output Fields (page 85).
Explain on Queries on Sharded Collections For queries on sharded collections, explain() (page 83) returns
information for each shard the query accesses. For queries on unsharded collections, see Core Explain Output Fields
(page 85).
For queries on a sharded collection, the output contains the Core Explain Output Fields (page 85) for each accessed
shard and cumulative shard information (page 87):
84 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
"clusteredType" : "<Shard Access Type>",
"shards" : {
"<shard1>" : [
{
<core explain output>
}
],
"<shard2>" : [
{
<core explain output>
}
],
...
},
"millisShardTotal" : <num>,
"millisShardAvg" : <num>,
"numQueries" : <num>,
"numShards" : <num>,
"cursor" : "<Cursor Type and Index>",
"n" : <num>,
"nChunkSkips" : <num>,
"nYields" : <num>,
"nscanned" : <num>,
"nscannedAllPlans" : <num>,
"nscannedObjects" : <num>,
"nscannedObjectsAllPlans" : <num>,
"millis" : <num>
}
For details on these elds, see Core Explain Output Fields (page 85) for each accessed shard and Sharded Collections
Output Fields (page 87).
Explain Output Fields
Core Explain Output Fields This section explains output for queries on collections that are not sharded. For queries
on sharded collections, see Explain on Queries on Sharded Collections (page 84).
explain.cursor
cursor (page 85) is a string that reports the type of cursor used by the query operation:
BasicCursor indicates a full collection scan.
BtreeCursor indicates that the query used an index. The cursor includes name of the index. When a
query uses an index, the output of explain() (page 83) includes indexBounds (page 86) details.
GeoSearchCursor indicates that the query used a geospatial index.
Complex Plan indicates that MongoDB used index intersection.
For BtreeCursor cursors, MongoDB will append the name of the index to the cursor string. Additionally,
depending on how the query uses an index, MongoDB may append one or both of the following strings to the
cursor string:
reverse indicates that query transverses the index from the highest values to the lowest values (e.g.
right to left.)
2.1. mongo Shell Methods 85
MongoDB Reference Manual, Release 2.6.4
multi indicates that the query performed multiple look-ups. Otherwise, the query uses the index to
determine a range of possible matches.
explain.isMultiKey
isMultiKey (page 86) is a boolean. When true, the query uses a multikey index, where one of the elds in
the index holds an array.
explain.n
n (page 86) is a number that reects the number of documents that match the query selection criteria.
explain.nscannedObjects
Species the total number of documents scanned during the query. The nscannedObjects (page 86) may be
lower than nscanned (page 86), such as if the index covers a query. See indexOnly (page 86). Additionally,
the nscannedObjects (page 86) may be lower than nscanned (page 86) in the case of multikey index on
an array eld with duplicate documents.
explain.nscanned
Species the total number of documents or index entries scanned during the database operation. You want n
(page 86) and nscanned (page 86) to be close in value as possible. The nscanned (page 86) value may be
higher than the nscannedObjects (page 86) value, such as if the index covers a query. See indexOnly
(page 86).
explain.nscannedObjectsAllPlans
New in version 2.2.
nscannedObjectsAllPlans (page 86) is a number that reects the total number of documents scanned
for all query plans during the database operation.
explain.nscannedAllPlans
New in version 2.2.
nscannedAllPlans (page 86) is a number that reects the total number of documents or index entries
scanned for all query plans during the database operation.
explain.scanAndOrder
scanAndOrder (page 86) is a boolean that is true when the query cannot use the order of documents in
the index for returning sorted results: MongoDB must sort the documents after it receives the documents from
a cursor.
If scanAndOrder (page 86) is false, MongoDB can use the order of the documents in an index to return
sorted results.
explain.indexOnly
indexOnly (page 86) is a boolean value that returns true when the query is covered by the index indicated
in the cursor (page 85) eld. When an index covers a query, MongoDB can both match the query conditions
and return the results using only the index because:
all the elds in the query are part of that index, and
all the elds returned in the results set are in the same index.
explain.nYields
nYields (page 86) is a number that reects the number of times this query yielded the read lock to allow
waiting writes to execute.
explain.nChunkSkips
nChunkSkips (page 86) is a number that reects the number of documents skipped because of active chunk
migrations in a sharded system. Typically this will be zero. A number greater than zero is ok, but indicates a
little bit of inefciency.
explain.millis
millis (page 86) is a number that reects the time in milliseconds to complete the query.
86 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
explain.indexBounds
indexBounds (page 86) is a document that contains the lower and upper index key bounds. This eld resem-
bles one of the following:
"indexBounds" : {
"start" : { <index key1> : <value>, ... },
"end" : { <index key1> : <value>, ... }
},
"indexBounds" : { "<field>" : [ [ <lower bound>, <upper bound> ] ],
...
}
explain.allPlans
allPlans (page 87) is an array that holds the list of plans the query optimizer runs in order to select the index
for the query. Displays only when the <verbose> parameter to explain() (page 83) is true or 1.
explain.oldPlan
New in version 2.2.
oldPlan (page 87) is a document value that contains the previous plan selected by the query optimizer for the
query. Displays only when the <verbose> parameter to explain() (page 83) is true or 1.
explain.server
New in version 2.2.
server (page 87) is a string that reports the MongoDB server.
explain.filterSet
New in version 2.6.
filterSet (page 87) is a boolean that indicates whether MongoDB applied an index lter for the query.
$or Query Output Fields
explain.clauses
clauses (page 87) is an array that holds the Core Explain Output Fields (page 85) information for each clause
of the $or (page 393) expression. clauses (page 87) is only included when the clauses in the $or (page 393)
expression use indexes.
Sharded Collections Output Fields
explain.clusteredType
clusteredType (page 87) is a string that reports the access pattern for shards. The value is:
ParallelSort, if the mongos (page 571) queries shards in parallel.
SerialServer, if the mongos (page 571) queries shards sequentially.
explain.shards
shards (page 87) contains elds for each shard in the cluster accessed during the query. Each eld holds the
Core Explain Output Fields (page 85) for that shard.
explain.millisShardTotal
millisShardTotal (page 87) is a number that reports the total time in milliseconds for the query to run on
the shards.
explain.millisShardAvg
millisShardAvg (page 87) is a number that reports the average time in millisecond for the query to run on
each shard.
2.1. mongo Shell Methods 87
MongoDB Reference Manual, Release 2.6.4
explain.numQueries
numQueries (page 87) is a number that reports the total number of queries executed.
explain.numShards
numShards (page 88) is a number that reports the total number of shards queried.
cursor.forEach()
Description
cursor.forEach(function)
Iterates the cursor to apply a JavaScript function to each document from the cursor.
The forEach() (page 88) method has the following prototype form:
db.collection.find().forEach(<function>)
The forEach() (page 88) method has the following parameter:
param JavaScript function A JavaScript function to apply to each document from the cursor. The
<function> signature includes a single argument that is passed the current document to pro-
cess.
Example The following example invokes the forEach() (page 88) method on the cursor returned by find()
(page 33) to print the name of each user in the collection:
db.users.find().forEach( function(myDoc) { print( "user: " + myDoc.name ); } );
See also:
cursor.map() (page 89) for similar functionality.
cursor.hasNext()
cursor.hasNext()
Returns Boolean.
cursor.hasNext() (page 88) returns true if the cursor returned by the db.collection.find()
(page 33) query can iterate further to return more documents.
cursor.hint()
Denition
cursor.hint(index)
Call this method on a query to override MongoDBs default index selection and query optimization
process. Use db.collection.getIndexes() (page 45) to return the list of current indexes on a col-
lection.
The cursor.hint() (page 88) method has the following parameter:
param string,document index The index to hint or force MongoDB to use when performing the
query. Specify the index either by the index name or by the index specication document.
88 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Behavior When an index lter exists for the query shape, MongoDB ignores the hint() (page 88). The
explain.filterSet (page 87) eld of the explain() (page 83) output indicates whether MongoDB applied
an index lter for the query.
You cannot use hint() (page 88) if the query includes a $text (page 401) query expression.
Example The following example returns all documents in the collection named users using the index on the age
eld.
db.users.find().hint( { age: 1 } )
You can also specify the index using the index name:
db.users.find().hint( "age_1" )
See also:
http://docs.mongodb.org/manualcore/indexes-introduction
http://docs.mongodb.org/manualadministration/indexes
http://docs.mongodb.org/manualcore/query-plans
index-lters
$hint (page 529)
cursor.limit()
Denition
cursor.limit()
Use the limit() (page 89) method on a cursor to specify the maximum number of documents the cursor will
return. limit() (page 89) is analogous to the LIMIT statement in a SQL database.
Note: You must apply limit() (page 89) to the cursor before retrieving any documents from the database.
Use limit() (page 89) to maximize performance and prevent MongoDB from returning more results than
required for processing.
Behavior
Supported Values The behavior of limit() (page 89) is undened for values less than -2
31
and greater than 2
31
.
Negative Values A limit() (page 89) value of 0 (i.e. .limit(0) (page 89)) is equivalent to setting no limit. A
negative limit is similar to a positive limit, but a negative limit prevents the creation of a cursor such that only a single
batch of results is returned. As such, with a negative limit, if the limited result set does not t into a single batch, the
number of documents received will be less than the limit.
cursor.map()
cursor.map(function)
Applies function to each document visited by the cursor and collects the return values from successive
application into an array.
2.1. mongo Shell Methods 89
MongoDB Reference Manual, Release 2.6.4
The cursor.map() (page 89) method has the following parameter:
param function function A function to apply to each document visited by the cursor.
Example
db.users.find().map( function(u) { return u.name; } );
See also:
cursor.forEach() (page 88) for similar functionality.
cursor.max()
Denition
cursor.max()
Species the exclusive upper bound for a specic index in order to constrain the results of find() (page 33).
max() (page 90) provides a way to specify an upper bound on compound key indexes.
The max() (page 90) method has the following parameter:
param document indexBounds The exclusive upper bound for the index keys.
The indexBounds parameter has the following prototype form:
{ field1: <max value>, field2: <max value2> ... fieldN:<max valueN>}
The elds correspond to all the keys of a particular index in order. You can explicitly specify the particular
index with the hint() (page 88) method. Otherwise, mongod (page 555) selects the index using the elds in
the indexBounds; however, if multiple indexes exist on same elds with different sort orders, the selection
of the index may be ambiguous.
See also:
min() (page 92).
Note: max() (page 90) is a shell wrapper around the query modier $max (page 530).
Behavior
Because max() (page 90) requires an index on a eld, and forces the query to use this index, you may prefer
the $lt (page 388) operator for the query if possible. Consider the following example:
db.products.find( { _id: 7 } ).max( { price: 1.39 } )
The query will use the index on the price eld, even if the index on _id may be better.
max() (page 90) exists primarily to support the mongos (page 571) (sharding) process.
If you use max() (page 90) with min() (page 92) to specify a range, the index bounds specied in min()
(page 92) and max() (page 90) must both refer to the keys of the same index.
Example This example assumes a collection named products that holds the following documents:
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : 1.29 }
{ "_id" : 2, "item" : "apple", "type" : "fuji", "price" : 1.99 }
{ "_id" : 1, "item" : "apple", "type" : "honey crisp", "price" : 1.99 }
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : 1.29 }
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : 1.29 }
90 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : 1.29 }
{ "_id" : 7, "item" : "orange", "type" : "cara cara", "price" : 2.99 }
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : 1.39 }
{ "_id" : 9, "item" : "orange", "type" : "satsuma", "price" : 1.99 }
{ "_id" : 8, "item" : "orange", "type" : "valencia", "price" : 0.99 }
The collection has the following indexes:
{ "_id" : 1 }
{ "item" : 1, "type" : 1 }
{ "item" : 1, "type" : -1 }
{ "price" : 1 }
Using the ordering of { item: 1, type: 1 } index, max() (page 90) limits the query to the docu-
ments that are below the bound of item equal to apple and type equal to jonagold:
db.products.find().max( { item: 'apple', type: 'jonagold' } ).hint( { item: 1, type: 1 } )
The query returns the following documents:
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : 1.29 }
{ "_id" : 2, "item" : "apple", "type" : "fuji", "price" : 1.99 }
{ "_id" : 1, "item" : "apple", "type" : "honey crisp", "price" : 1.99 }
If the query did not explicitly specify the index with the hint() (page 88) method, it is ambiguous as to whether
mongod (page 555) would select the { item: 1, type: 1 } index ordering or the { item: 1,
type: -1 } index ordering.
Using the ordering of the index { price: 1 }, max() (page 90) limits the query to the documents that are
below the index key bound of price equal to 1.99 and min() (page 92) limits the query to the documents
that are at or above the index key bound of price equal to 1.39:
db.products.find().min( { price: 1.39 } ).max( { price: 1.99 } ).hint( { price: 1 } )
The query returns the following documents:
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : 1.29 }
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : 1.29 }
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : 1.29 }
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : 1.29 }
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : 1.39 }
cursor.maxTimeMS()
Denition New in version 2.6.
cursor.maxTimeMS(<time limit>)
Species a cumulative time limit in milliseconds for processing operations on a cursor.
The maxTimeMS() (page 91) method has the following parameter:
param integer milliseconds Species a cumulative time limit in milliseconds for processing oper-
ations on the cursor.
Important: maxTimeMS() (page 91) is not related to the NoCursorTimeout query ag. maxTimeMS()
(page 91) relates to processing time, while NoCursorTimeout relates to idle time. A cursors idle time does not
contribute towards its processing time.
2.1. mongo Shell Methods 91
MongoDB Reference Manual, Release 2.6.4
Behaviors MongoDB targets operations for termination if the associated cursor exceeds its allotted time limit.
MongoDB terminates operations that exceed their allotted time limit, using the same mechanism as db.killOp()
(page 120). MongoDB only terminates an operation at one of its designated interrupt points.
MongoDB does not count network latency towards a cursors time limit.
Queries that generate multiple batches of results continue to return batches until the cursor exceeds its allotted time
limit.
Examples
Example
The following query species a time limit of 50 milliseconds:
db.collection.find({description: /August [0-9]+, 1969/}).maxTimeMS(50)
cursor.min()
Denition
cursor.min()
Species the inclusive lower bound for a specic index in order to constrain the results of find() (page 33).
min() (page 92) provides a way to specify lower bounds on compound key indexes.
The min() (page 92) has the following parameter:
param document indexBounds The inclusive lower bound for the index keys.
The indexBounds parameter has the following prototype form:
{ field1: <min value>, field2: <min value2>, fieldN:<min valueN> }
The elds correspond to all the keys of a particular index in order. You can explicitly specify the particular
index with the hint() (page 88) method. Otherwise, MongoDB selects the index using the elds in the
indexBounds; however, if multiple indexes exist on same elds with different sort orders, the selection of the
index may be ambiguous.
See also:
max() (page 90).
Note: min() (page 92) is a shell wrapper around the query modier $min (page 531).
Behaviors
Because min() (page 92) requires an index on a eld, and forces the query to use this index, you may prefer
the $gte (page 387) operator for the query if possible. Consider the following example:
db.products.find( { _id: 7 } ).min( { price: 1.39 } )
The query will use the index on the price eld, even if the index on _id may be better.
min() (page 92) exists primarily to support the mongos (page 571) process.
If you use min() (page 92) with max() (page 90) to specify a range, the index bounds specied in min()
(page 92) and max() (page 90) must both refer to the keys of the same index.
92 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example This example assumes a collection named products that holds the following documents:
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : 1.29 }
{ "_id" : 2, "item" : "apple", "type" : "fuji", "price" : 1.99 }
{ "_id" : 1, "item" : "apple", "type" : "honey crisp", "price" : 1.99 }
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : 1.29 }
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : 1.29 }
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : 1.29 }
{ "_id" : 7, "item" : "orange", "type" : "cara cara", "price" : 2.99 }
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : 1.39 }
{ "_id" : 9, "item" : "orange", "type" : "satsuma", "price" : 1.99 }
{ "_id" : 8, "item" : "orange", "type" : "valencia", "price" : 0.99 }
The collection has the following indexes:
{ "_id" : 1 }
{ "item" : 1, "type" : 1 }
{ "item" : 1, "type" : -1 }
{ "price" : 1 }
Using the ordering of the { item: 1, type: 1 } index, min() (page 92) limits the query to the
documents that are at or above the index key bound of item equal to apple and type equal to jonagold,
as in the following:
db.products.find().min( { item: 'apple', type: 'jonagold' } ).hint( { item: 1, type: 1 } )
The query returns the following documents:
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : 1.29 }
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : 1.29 }
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : 1.29 }
{ "_id" : 7, "item" : "orange", "type" : "cara cara", "price" : 2.99 }
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : 1.39 }
{ "_id" : 9, "item" : "orange", "type" : "satsuma", "price" : 1.99 }
{ "_id" : 8, "item" : "orange", "type" : "valencia", "price" : 0.99 }
If the query did not explicitly specify the index with the hint() (page 88) method, it is ambiguous as to whether
mongod (page 555) would select the { item: 1, type: 1 } index ordering or the { item: 1,
type: -1 } index ordering.
Using the ordering of the index { price: 1 }, min() (page 92) limits the query to the documents that
are at or above the index key bound of price equal to 1.39 and max() (page 90) limits the query to the
documents that are below the index key bound of price equal to 1.99:
db.products.find().min( { price: 1.39 } ).max( { price: 1.99 } ).hint( { price: 1 } )
The query returns the following documents:
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : 1.29 }
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : 1.29 }
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : 1.29 }
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : 1.29 }
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : 1.39 }
cursor.next()
cursor.next()
2.1. mongo Shell Methods 93
MongoDB Reference Manual, Release 2.6.4
Returns The next document in the cursor returned by the db.collection.find() (page 33)
method. See cursor.hasNext() (page 88) related functionality.
cursor.objsLeftInBatch()
cursor.objsLeftInBatch()
cursor.objsLeftInBatch() (page 94) returns the number of documents remaining in the current batch.
The MongoDB instance returns response in batches. To retrieve all the documents from a cursor may require
multiple batch responses from the MongoDB instance. When there are no more documents remaining in the
current batch, the cursor will retrieve another batch to get more documents until the cursor exhausts.
cursor.readPref()
Denition
cursor.readPref(mode, tagSet)
Append readPref() (page 94) to a cursor to control how the client routes the query to members of the replica
set.
param string mode One of the following read preference modes: primary,
primaryPreferred, secondary, secondaryPreferred, or nearest
param array tagSet A tag set used to specify custom read preference modes. For details, see
replica-set-read-preference-tag-sets.
Note: You must apply readPref() (page 94) to the cursor before retrieving any documents from the
database.
cursor.showDiskLoc()
cursor.showDiskLoc()
Modies the output of a query by adding a eld $diskLoc to matching documents. $diskLoc contains disk
location information and has the form:
"$diskLoc": {
"file": <int>,
"offset": <int>
}
cursor.showDiskLoc() (page 94) method is a wrapper around $showDiskLoc (page 533).
Returns A modied cursor object that contains documents with appended information that describes
the on-disk location of the document.
Example The following operation appends the showDiskLoc() (page 94) method to the
db.collection.find() (page 33) method in order to include in the matching documents the disk loca-
tion information:
db.collection.find( { a: 1 } ).showDiskLoc()
The operation returns the following documents, which includes the $diskLoc eld:
94 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
"_id" : ObjectId("53908ccb18facd50a75bfbac"),
"a" : 1,
"b" : 1,
"$diskLoc" : { "file" : 0, "offset" : 16195760 }
}
{
"_id" : ObjectId("53908cd518facd50a75bfbad"),
"a" : 1,
"b" : 2,
"$diskLoc" : { "file" : 0, "offset" : 16195824 }
}
The projection can also access the added eld $diskLoc, as in the following example:
db.collection.find( { a: 1 }, { $diskLoc: 1 } ).showDiskLoc()
The operation returns just the _id eld and the $diskLoc eld in the matching documents:
{
"_id" : ObjectId("53908ccb18facd50a75bfbac"),
"$diskLoc" : { "file" : 0, "offset" : 16195760 }
}
{
"_id" : ObjectId("53908cd518facd50a75bfbad"),
"$diskLoc" : { "file" : 0, "offset" : 16195824 }
}
See also:
$showDiskLoc (page 533) for related functionality.
cursor.size()
cursor.size()
Returns A count of the number of documents that match the db.collection.find()
(page 33) query after applying any cursor.skip() (page 95) and cursor.limit()
(page 89) methods.
cursor.skip()
cursor.skip()
Call the cursor.skip() (page 95) method on a cursor to control where MongoDB begins returning results.
This approach may be useful in implementing paged results.
Note: You must apply cursor.skip() (page 95) to the cursor before retrieving any documents from the
database.
Consider the following JavaScript function as an example of the skip function:
function printStudents(pageNumber, nPerPage) {
print("Page: " + pageNumber);
db.students.find().skip(pageNumber > 0 ? ((pageNumber-1)
*
nPerPage) : 0).limit(nPerPage).forEach( function(student) { print(student.name + "<p>"); } );
}
2.1. mongo Shell Methods 95
MongoDB Reference Manual, Release 2.6.4
The cursor.skip() (page 95) method is often expensive because it requires the server to walk from the
beginning of the collection or index to get the offset or skip position before beginning to return result. As
offset (e.g. pageNumber above) increases, cursor.skip() (page 95) will become slower and more CPU
intensive. With larger collections, cursor.skip() (page 95) may become IO bound.
Consider using range-based pagination for these kinds of tasks. That is, query for a range of objects, using logic
within the application to determine the pagination rather than the database itself. This approach features better
index utilization, if you do not need to easily jump to a specic page.
cursor.snapshot()
cursor.snapshot()
Append the snapshot() (page 96) method to a cursor to toggle the snapshot mode. This ensures that the
query will not return a document multiple times, even if intervening write operations result in a move of the
document due to the growth in document size.
Warning:
You must apply snapshot() (page 96) to the cursor before retrieving any documents from the
database.
You can only use snapshot() (page 96) with unsharded collections.
The snapshot() (page 96) does not guarantee isolation from insertion or deletions.
The snapshot() (page 96) traverses the index on the _id eld. As such, snapshot() (page 96) cannot
be used with sort() (page 96) or hint() (page 88).
Queries with results of less than 1 megabyte are effectively implicitly snapshotted.
cursor.sort()
Denition
cursor.sort(sort)
Species the order in which the query returns matching documents. You must apply sort() (page 96) to the
cursor before retrieving any documents from the database.
The sort() (page 96) method has the following parameter:
param document sort A document that denes the sort order of the result set.
The sort parameter contains eld and value pairs, in the following form:
{ field: value }
The sort document can specify ascending or descending sort on existing elds (page 97) or sort on computed
metadata (page 97).
Behaviors
Result Ordering Unless you specify the sort() (page 96) method or use the $near (page 410) operator, Mon-
goDB does not guarantee the order of query results.
96 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Ascending/Descending Sort Specify in the sort parameter the eld or elds to sort by and a value of 1 or -1 to
specify an ascending or descending sort respectively.
The following sample document species a descending sort by the age eld and then an ascending sort by the posts
eld:
{ age : -1, posts: 1 }
When comparing values of different BSON types, MongoDB uses the following comparison order, from lowest to
highest:
1. MinKey (internal type)
2. Null
3. Numbers (ints, longs, doubles)
4. Symbol, String
5. Object
6. Array
7. BinData
8. ObjectId
9. Boolean
10. Date, Timestamp
11. Regular Expression
12. MaxKey (internal type)
MongoDB treats some types as equivalent for comparison purposes. For instance, numeric types undergo conversion
before comparison.
The comparison treats a non-existent eld as it would an empty BSON Object. As such, a sort on the a eld in
documents { } and { a: null } would treat the documents as equivalent in sort order.
With arrays, a less-than comparison or an ascending sort compares the smallest element of arrays, and a greater-than
comparison or a descending sort compares the largest element of the arrays. As such, when comparing a eld whose
value is a single-element array (e.g. [ 1 ]) with non-array elds (e.g. 2), the comparison is between 1 and 2. A
comparison of an empty array (e.g. [ ]) treats the empty array as less than null or a missing eld.
MongoDB sorts BinData in the following order:
1. First, the length or size of the data.
2. Then, by the BSON one-byte subtype.
3. Finally, by the data, performing a byte-by-byte comparison.
Metadata Sort Specify in the sort parameter a new eld name for the computed metadata and specify the $meta
(page 427) expression as its value.
The following sample document species a descending sort by the "textScore" metadata:
{ score: { $meta: "textScore" } }
The specied metadata determines the sort order. For example, the "textScore" metadata sorts in descending
order. See $meta (page 427) for details.
2.1. mongo Shell Methods 97
MongoDB Reference Manual, Release 2.6.4
Limit Results The sort operation requires that the entire sort be able to complete within 32 megabytes.
When the sort operation consumes more than 32 megabytes, MongoDB returns an error. To avoid this error, either
create an index to support the sort operation or use sort() (page 96) in conjunction with limit() (page 89). The
specied limit must result in a number of documents that fall within the 32 megabyte limit.
For example, if the following sort operation stocks_quotes exceeds the 32 megabyte limit:
db.stocks.find().sort( { ticker: 1, date: -1 } )
Either create an index to support the sort operation:
db.stocks.ensureIndex( { ticker: 1, date: -1 } )
Or use sort() (page 96) in conjunction with limit() (page 89):
db.stocks.find().sort( { ticker: 1, date: -1 } ).limit(100)
Interaction with Projection When a set of results are both sorted and projected, the MongoDB query engine will
always apply the sorting rst.
Examples A collection orders contain the following documents:
{ _id: 1, item: { category: "cake", type: "chiffon" }, amount: 10 }
{ _id: 2, item: { category: "cookies", type: "chocolate chip" }, amount: 50 }
{ _id: 3, item: { category: "cookies", type: "chocolate chip" }, amount: 15 }
{ _id: 4, item: { category: "cake", type: "lemon" }, amount: 30 }
{ _id: 5, item: { category: "cake", type: "carrot" }, amount: 20 }
{ _id: 6, item: { category: "brownies", type: "blondie" }, amount: 10 }
The following query, which returns all documents from the orders collection, does not specify a sort order:
db.orders.find()
The query returns the documents in indeterminate order:
{ "_id" : 1, "item" : { "category" : "cake", "type" : "chiffon" }, "amount" : 10 }
{ "_id" : 2, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 50 }
{ "_id" : 3, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 15 }
{ "_id" : 4, "item" : { "category" : "cake", "type" : "lemon" }, "amount" : 30 }
{ "_id" : 5, "item" : { "category" : "cake", "type" : "carrot" }, "amount" : 20 }
{ "_id" : 6, "item" : { "category" : "brownies", "type" : "blondie" }, "amount" : 10 }
The following query species a sort on the amount eld in descending order.
db.orders.find().sort( { amount: -1 } )
The query returns the following documents, in descending order of amount:
{ "_id" : 2, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 50 }
{ "_id" : 4, "item" : { "category" : "cake", "type" : "lemon" }, "amount" : 30 }
{ "_id" : 5, "item" : { "category" : "cake", "type" : "carrot" }, "amount" : 20 }
{ "_id" : 3, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 15 }
{ "_id" : 1, "item" : { "category" : "cake", "type" : "chiffon" }, "amount" : 10 }
{ "_id" : 6, "item" : { "category" : "brownies", "type" : "blondie" }, "amount" : 10 }
The following query species the sort order using the elds from a sub-document item. The query sorts rst by the
category eld in ascending order, and then within each category, by the type eld in ascending order.
98 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.orders.find().sort( { "item.category": 1, "item.type": 1 } )
The query returns the following documents, ordered rst by the category eld, and within each category, by the
type eld:
{ "_id" : 6, "item" : { "category" : "brownies", "type" : "blondie" }, "amount" : 10 }
{ "_id" : 5, "item" : { "category" : "cake", "type" : "carrot" }, "amount" : 20 }
{ "_id" : 1, "item" : { "category" : "cake", "type" : "chiffon" }, "amount" : 10 }
{ "_id" : 4, "item" : { "category" : "cake", "type" : "lemon" }, "amount" : 30 }
{ "_id" : 2, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 50 }
{ "_id" : 3, "item" : { "category" : "cookies", "type" : "chocolate chip" }, "amount" : 15 }
Return in Storage Order The $natural (page 535) parameter returns items according to their storage order
within the collection level extents.
Typically, the storage order reects insertion order, except when documents relocate because of document growth due
to updates or remove operations free up space which are then taken up by newly inserted documents.
Consider the sequence of insert operations to the trees collection:
db.trees.insert( { _id: 1, common_name: "oak", genus: "quercus" } )
db.trees.insert( { _id: 2, common_name: "chestnut", genus: "castanea" } )
db.trees.insert( { _id: 3, common_name: "maple", genus: "aceraceae" } )
db.trees.insert( { _id: 4, common_name: "birch", genus: "betula" } )
The following query returns the documents in the storage order:
db.trees.find().sort( { $natural: 1 } )
The documents return in the following order:
{ "_id" : 1, "common_name" : "oak", "genus" : "quercus" }
{ "_id" : 2, "common_name" : "chestnut", "genus" : "castanea" }
{ "_id" : 3, "common_name" : "maple", "genus" : "aceraceae" }
{ "_id" : 4, "common_name" : "birch", "genus" : "betula" }
Update a document such that the document outgrows its current allotted space:
db.trees.update(
{ _id: 1 },
{ $set: { famous_oaks: [ "Emancipation Oak", "Goethe Oak" ] } }
)
Rerun the query to returns the documents in the storage order:
db.trees.find().sort( { $natural: 1 } )
The documents return in the following storage order:
{ "_id" : 2, "common_name" : "chestnut", "genus" : "castanea" }
{ "_id" : 3, "common_name" : "maple", "genus" : "aceraceae" }
{ "_id" : 4, "common_name" : "birch", "genus" : "betula" }
{ "_id" : 1, "common_name" : "oak", "genus" : "quercus", "famous_oaks" : [ "Emancipation Oak", "Goethe Oak" ] }
See also:
$natural (page 535)
2.1. mongo Shell Methods 99
MongoDB Reference Manual, Release 2.6.4
cursor.toArray()
cursor.toArray()
The toArray() (page 100) method returns an array that contains all the documents from a cursor. The method
iterates completely the cursor, loading all the documents into RAM and exhausting the cursor.
Returns An array of documents.
Consider the following example that applies toArray() (page 100) to the cursor returned from the find()
(page 33) method:
var allProductsArray = db.products.find().toArray();
if (allProductsArray.length > 0) { printjson (allProductsArray[0]); }
The variable allProductsArray holds the array of documents returned by toArray() (page 100).
2.1.3 Database
Database Methods
Name Description
db.addUser() (page 148) Adds a user to a database, and allows administrators to congure the users privileges.
db.auth() (page 102) Authenticates a user to a database.
db.changeUserPassword() (page 150) Changes an existing users password.
db.cloneCollection() (page 103) Copies data directly between MongoDB instances. Wraps cloneCollection (page 313).
db.cloneDatabase() (page 104) Copies a database from a remote host to the current host. Wraps clone (page 313).
db.commandHelp() (page 104) Returns help information for a database command.
db.copyDatabase() (page 104) Copies a database to another database on the current host. Wraps copydb (page 319).
db.createCollection() (page 106) Creates a new collection. Commonly used to create a capped collection.
db.currentOp() (page 107) Reports the current in-progress operations.
db.dropDatabase() (page 113) Removes the current database.
db.eval() (page 113) Passes a JavaScript function to the mongod (page 555) instance for server-side JavaScript evaluation.
db.fsyncLock() (page 115) Flushes writes to disk and locks the database to prevent write operations and assist backup operations. Wraps fsync (page 328).
db.fsyncUnlock() (page 115) Allows writes to continue on a database locked with db.fsyncLock() (page 115).
db.getCollection() (page 116) Returns a collection object. Used to access collections with names that are not valid in the mongo (page 580) shell.
db.getCollectionNames() (page 116) Lists all collections in the current database.
db.getLastError() (page 116) Checks and returns the status of the last operation. Wraps getLastError (page 243).
db.getLastErrorObj() (page 116) Returns the status document for the last operation. Wraps getLastError (page 243).
db.getMongo() (page 117) Returns the Mongo() (page 200) connection object for the current connection.
db.getName() (page 117) Returns the name of the current database.
db.getPrevError() (page 117) Returns a status document containing all errors since the last error reset. Wraps getPrevError (page 245).
db.getProfilingLevel() (page 117) Returns the current proling level for database operations.
db.getProfilingStatus() (page 117) Returns a document that reects the current proling level and the proling threshold.
db.getReplicationInfo() (page 117) Returns a document with replication statistics.
db.getSiblingDB() (page 118) Provides access to the specied database.
db.help() (page 119) Displays descriptions of common db object methods.
db.hostInfo() (page 119) Returns a document with information about the system MongoDB runs on. Wraps hostInfo (page 345)
db.isMaster() (page 120) Returns a document that reports the state of the replica set.
db.killOp() (page 120) Terminates a specied operation.
db.listCommands() (page 120) Displays a list of common database commands.
db.loadServerScripts() (page 120) Loads all scripts in the system.js collection for the current database into the shell session.
db.logout() (page 121) Ends an authenticated session.
Continued on next page
100 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Table 2.2 continued from previous page
Name Description
db.printCollectionStats() (page 121) Prints statistics from every collection. Wraps db.collection.stats() (page 69).
db.printReplicationInfo() (page 121) Prints a report of the status of the replica set from the perspective of the primary.
db.printShardingStatus() (page 122) Prints a report of the sharding conguration and the chunk ranges.
db.printSlaveReplicationInfo() (page 123) Prints a report of the status of the replica set from the perspective of the secondaries.
db.removeUser() (page 155) Removes a user from a database.
db.repairDatabase() (page 123) Runs a repair routine on the current database.
db.resetError() (page 124) Resets the error message returned by db.getPrevError() (page 117) and getPrevError (page 245).
db.runCommand() (page 124) Runs a database command (page 208).
db.serverBuildInfo() (page 124) Returns a document that displays the compilation parameters for the mongod (page 555) instance. Wraps buildinfo.
db.serverCmdLineOpts() (page 124) Returns a document with information about the runtime used to start the MongoDB instance. Wraps getCmdLineOpts (page 344).
db.serverStatus() (page 125) Returns a document that provides an overview of the state of the database process.
db.setProfilingLevel() (page 125) Modies the current level of database proling.
db.shutdownServer() (page 125) Shuts down the current mongod (page 555) or mongos (page 571) process cleanly and safely.
db.stats() (page 126) Returns a document that reports on the state of the current database.
db.upgradeCheck() (page 126) Performs a preliminary check for upgrade preparedness for a specic database or collection.
db.upgradeCheckAllDBs() (page 128) Performs a preliminary check for upgrade preparedness for all databases and collections.
db.version() (page 129) Returns the version of the mongod (page 555) instance.
db.addUser()
Deprecated since version 2.6: Use db.createUser() (page 150) and db.updateUser() (page 157) instead of
db.addUser() (page 148) to add users to MongoDB.
In 2.6, MongoDB introduced a new model for user credentials and privileges, as described in
http://docs.mongodb.org/manualcore/security-introduction. To use db.addUser()
(page 148) on MongoDB 2.4, see db.addUser() in the version 2.4 of the MongoDB Manual
8
.
Denition
db.addUser(document)
Adds a new user on the database where you run the method. The db.addUser() (page 148) method takes a
user document as its argument:
db.addUser(<user document>)
Specify a document that resembles the following as an argument to db.addUser() (page 148):
{ user: "<name>",
pwd: "<cleartext password>",
customData: { <any information> },
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
The db.addUser() (page 148) user document has the following elds:
eld string user The name of the new user.
eld string pwd The users password. The pwd eld is not required if you run db.addUser()
(page 148) on the $external database to create users who have credentials stored externally
to MongoDB.
8
http://docs.mongodb.org/v2.4/reference/method/db.addUser
2.1. mongo Shell Methods 101
MongoDB Reference Manual, Release 2.6.4
any document customData Any arbitrary information. This eld can be used to store any data an
admin wishes to associate with this particular user. For example, this could be the users full
name or employee id.
eld array roles The roles granted to the user. Can specify an empty array [] to create users without
roles.
eld document writeConcern The level of write concern for the creation operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Users created on the $external database should have credentials stored externally to MongoDB, as, for
example, with MongoDB Enterprise installations that use Kerberos.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.addUser() (page 148) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Considerations The db.addUser() (page 148) method returns a duplicate user error if the user exists.
When interacting with 2.6 and later MongoDB instances, db.addUser() (page 148) sends unencrypted passwords.
To encrypt the password in transit use SSL.
In the 2.6 version of the shell, db.addUser() (page 148) is backwards compatible with both the 2.4 version of
db.addUser()
9
and the 2.2 version of db.addUser()
10
. In 2.6, for backwards compatibility db.addUser() (page 148)
creates users that approximate the privileges available in previous versions of MongoDB.
Example The following db.addUser() (page 148) method creates a user Carlos on the database where the
command runs. The command gives Carlos the clusterAdmin and readAnyDatabase roles on the admin
database and the readWrite role on the current database:
{ user: "Carlos",
pwd: "cleartext password",
customData: { employeeId: 12345 },
roles: [
{ role: "clusterAdmin", db: "admin" },
{ role: "readAnyDatabase", db: "admin" },
"readWrite"
],
writeConcern: { w: "majority" , wtimeout: 5000 }
}
db.auth()
Denition
9
http://docs.mongodb.org/v2.4/reference/method/db.addUser
10
http://docs.mongodb.org/v2.2/reference/method/db.addUser
102 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.auth(username, password)
Allows a user to authenticate to the database from within the shell.
param string username Species an existing username with access privileges for this database.
param string password Species the corresponding password.
param string mechanism Species the authentication mechanism used. Defaults to
MONGODB-CR. PLAIN is used for SASL/LDAP authentication, available only in
MongoDB Enterprise.
Alternatively, you can use mongo --username, --password, and --authenticationMechanism
to specify authentication credentials.
--authenticationMechanism supports additional mechanisms not available when using db.auth()
(page 102).
Note: The mongo (page 580) shell excludes all db.auth() (page 102) operations from the saved history.
Returns db.auth() (page 102) returns 0 when authentication is not successful, and 1 when the
operation is successful.
db.changeUserPassword()
Denition
db.changeUserPassword(username, password)
Updates a users password.
param string username Species an existing username with access privileges for this database.
param string password Species the corresponding password.
param string mechanism Species the authentication mechanism used. Defaults to
MONGODB-CR. PLAIN is used for SASL/LDAP authentication, available only in
MongoDB Enterprise.
Example The following operation changes the reporting users password to SOh3TbYhx8ypJPxmt1oOfL:
db.changeUserPassword("reporting", "SOh3TbYhx8ypJPxmt1oOfL")
db.cloneCollection()
Denition
db.cloneCollection(from, collection, query)
Copies data directly between MongoDB instances. The db.cloneCollection() (page 103) wraps the
cloneCollection (page 313) database command and accepts the following arguments:
param string from Host name of the MongoDB instance that holds the collection to copy.
param string collection The collection in the MongoDB instance that you want to copy.
db.cloneCollection() (page 103) will only copy the collection with this name from
database of the same name as the current database the remote MongoDB instance. If you want
to copy a collection from a different database name you must use the cloneCollection
(page 313) directly.
2.1. mongo Shell Methods 103
MongoDB Reference Manual, Release 2.6.4
param document query A standard query document that limits the documents copied as part of the
db.cloneCollection() (page 103) operation. All query selectors (page 386) available to
the find() (page 33) are available here.
db.cloneCollection() (page 103) does not allow you to clone a collection through a mongos
(page 571). You must connect directly to the mongod (page 555) instance.
db.cloneDatabase()
Denition
db.cloneDatabase(hostname)
Copies a remote database to the current database. The command assumes that the remote database has the same
name as the current database.
param string hostname The hostname of the database to copy.
This method provides a wrapper around the MongoDB database command clone (page 313). The copydb
(page 319) database command provides related functionality.
Example To clone a database named importdb on a host named hostname, issue the following:
use importdb
db.cloneDatabase("hostname")
New databases are implicitly created, so the current host does not need to have a database named importdb for this
command to succeed.
db.commandHelp()
Description
db.commandHelp(command)
Displays help text for the specied database command. See the Database Commands (page 208).
The db.commandHelp() (page 104) method has the following parameter:
param string command The name of a database command.
db.copyDatabase()
Denition
db.copyDatabase(fromdb, todb, fromhost, username, password)
Copies a database from a remote host to the current host or copies a database to another database within the
current host. db.copyDatabase() (page 104) wraps the copydb (page 319) command and takes the
following arguments:
param string fromdb The name of the source database.
param string todb The name of the destination database.
param string fromhost The name of the source database host. Omit the hostname to copy from one
database to another on the same server.
eld string username The username credentials on the fromhost for authentication and autho-
rization.
104 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld string password The password on the fromhost for authentication and authorization. The
method does not transmit the password in plaintext.
Behavior Be aware of the following properties of db.copyDatabase() (page 104):
db.copyDatabase() (page 104) runs on the destination mongod (page 555) instance, i.e. the host receiving
the copied data.
db.copyDatabase() (page 104) creates the target database if it does not exist.
db.copyDatabase() (page 104) requires enough free disk space on the host instance for the copied
database. Use the db.stats() (page 126) operation to check the size of the database on the source mongod
(page 555) instance.
db.copyDatabase() (page 104) and clone (page 313) do not produce point-in-time snapshots of the
source database. Write trafc to the source or destination database during the copy process will result in diver-
gent data sets.
db.copyDatabase() (page 104) does not lock the destination server during its operation, so the copy will
occasionally yield to allow other operations to complete.
Required Access Changed in version 2.6.
The copydb (page 319) command requires the following authorization on the target and source databases.
Source Database (fromdb)
Source is non-admin Database If the source database is a non-admin database, you must have privileges that
specify find action on the source database, and find action on the system.js collection in the source database.
For example:
{ resource: { db: "mySourceDB", collection: "" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.js" }, actions: [ "find" ] }
If the source database is on a remote server, you also need the find action on the system.indexes and
system.namespaces collections in the source database; e.g.
{ resource: { db: "mySourceDB", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.namespaces" }, actions: [ "find" ] }
Source is admin Database If the source database is the admin database, you must have privileges that specify
find action on the admin database, and find action on the system.js, system.users, system.roles,
and system.version collections in the admin database. For example:
{ resource: { db: "admin", collection: "" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.js" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.roles" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find" ] }
If the source database is on a remote server, the you also need the find action on the system.indexes and
system.namespaces collections in the admin database; e.g.
{ resource: { db: "admin", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.namespaces" }, actions: [ "find" ] }
2.1. mongo Shell Methods 105
MongoDB Reference Manual, Release 2.6.4
Source Database is on a Remote Server If copying from a remote server and the remote server has authentica-
tion enabled, you must authenticate to the remote host as a user with the proper authorization. See Authentication
(page 106).
Target Database (todb)
Copy from non-admin Database If the source database is not the admin database, you must have privileges
that specify insert and createIndex actions on the target database, and insert action on the system.js
collection in the target database. For example:
{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] }
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] }
Copy from admin Database If the source database is the admin database, you must have privileges that
specify insert and createIndex actions on the target database, and insert action on the system.js,
system.users, system.roles, and system.version collections in the target database. For example:
{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] },
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.users" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.roles" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.version" }, actions: [ "insert" ] }
Authentication If copying from a remote server and the remote server has authentication enabled, then you must
include the <username> and <password>. The method does not transmit the password in plaintext.
Example To copy a database named records into a database named archive_records, use the following
invocation of db.copyDatabase() (page 104):
db.copyDatabase('records', 'archive_records')
See also:
clone (page 313)
db.createCollection()
Denition
db.createCollection(name, options)
Creates a new collection explicitly.
Because MongoDB creates a collection implicitly when the collection is rst referenced in a command, this
method is used primarily for creating new capped collections. This is also used to pre-allocate space for an
ordinary collection.
The db.createCollection() (page 106) method has the following prototype form:
db.createCollection(name, {capped: <boolean>, autoIndexId: <boolean>, size: <number>, max: <number>} )
The db.createCollection() (page 106) method has the following parameters:
param string name The name of the collection to create.
106 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
param document options Conguration options for creating a capped collection or for preallocat-
ing space in a new collection.
The options document creates a capped collection or preallocates space in a new ordinary collection. The
options document contains the following elds:
eld Boolean capped Enables a capped collection. To create a capped collection, specify true. If
you specify true, you must also set a maximum size in the size eld.
eld Boolean autoIndexId Specify false to disable the automatic creation of an index on the _id
eld. Before 2.2, the default value for autoIndexId was false. See _id Fields and Indexes
on Capped Collections (page 739) for more information.
Do not set autoIndexId to true for replicated collections.
eld number size Species a maximum size in bytes for a capped collection. The size eld is
required for capped collections, and ignored for other collections.
eld number max The maximum number of documents allowed in the capped collection. The
size limit takes precedence over this limit. If a capped collection reaches its maximum size
before it reaches the maximum number of documents, MongoDB removes old documents. If
you prefer to use this limit, ensure that the size limit, which is required, is sufcient to contain
the documents limit.
eld boolean usePowerOf2Sizes New in version 2.6: usePowerOf2Sizes (page 314) be-
came an option to db.createCollection() (page 106) when usePowerOf2Sizes
(page 314) became the default allocation strategy for all new collections by default.
Set to false to disable the usePowerOf2Sizes (page 314) allocation strategy for this col-
lection. Defaults to true unless the newCollectionsUsePowerOf2Sizes parameter is
set to false.
Example The following example creates a capped collection. Capped collections have maximum size or document
counts that prevent them from growing beyond maximum thresholds. All capped collections must specify a maximum
size and may also specify a maximum document count. MongoDB removes older documents if a collection reaches
the maximum size limit before it reaches the maximum document count. Consider the following example:
db.createCollection("log", { capped : true, size : 5242880, max : 5000 } )
This command creates a collection named log with a maximum size of 5 megabytes and a maximum of 5000 docu-
ments.
The following command simply pre-allocates a 2-gigabyte, uncapped collection named people:
db.createCollection("people", { size: 2147483648 } )
This command provides a wrapper around the database command create (page 326). See
http://docs.mongodb.org/manualcore/capped-collections for more information about capped
collections.
db.currentOp()
Denition
db.currentOp()
Returns a document that contains information on in-progress operations for the database instance.
db.currentOp() (page 107) method has the following form:
2.1. mongo Shell Methods 107
MongoDB Reference Manual, Release 2.6.4
db.currentOp(<operations>)
The db.currentOp() (page 107) method can take the following optional argument:
param boolean or document operations Species the operations to report on. Can pass either a
boolean or a document.
Specify true to include operations on idle connections and system operations. Specify a docu-
ment with query conditions to report only on operations that match the conditions. See Behavior
(page 108) for details.
Behavior If you pass in true to db.currentOp() (page 107), the method returns information on all operations,
including operations on idle connections and system operations.
db.currentOp(true)
Passing in true is equivalent to passing in a query document of { $all: true }.
If you pass a query document to db.currentOp() (page 107), the output returns information only for the current
operations that match the query. You can query on the Output Fields (page 110). See Examples (page 108).
You can also specify { $all: true } query document to return information on all in-progress operations,
including operations on idle connections and system operations. If you specify in the query document other conditions
as well as $all: true, only the $all: true applies.
Access Control On systems running with authorization, a user must have access that includes the inprog
action.
Examples The following examples use the db.currentOp() (page 107) method with various query documents
to lter the output.
Return all write operations waiting for a lock:
db.currentOp(
{
"waitingForLock" : true,
$or: [
{ "op" : { "$in" : [ "insert", "update", "remove" ] } },
{ "query.update": { $exists: true } },
{ "query.insert": { $exists: true } },
{ "query.remove": { $exists: true } }
]
}
)
Return all active running operations that have never yielded:
db.currentOp(
{
"active" : true,
"numYields" : 0,
"waitingForLock" : false
}
)
Return all active queries for database db1 that have been running longer than 3 seconds:
108 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.currentOp(
{
"active" : true,
"secs_running" : { "$gt" : 3 },
"ns" : /^db1./
}
)
Output Example The following is an example of db.currentOp() (page 107) output.
{
"inprog": [
{
"opid" : <number>,
"active" : <boolean>,
"secs_running" : <NumberLong()>,
"microsecs_running" : <number>,
"op" : <string>,
"ns" : <string>,
"query" : <document>,
"insert" : <document>,
"planSummary": <string>,
"client" : <string>,
"desc" : <string>,
"threadId" : <string>,
"connectionId" : <number>,
"locks" : {
"^" : <string>,
"^local" : <string>,
"^<database>" : <string>
},
"waitingForLock" : <boolean>,
"msg": <string>,
"progress" : {
"done" : <number>,
"total" : <number>
},
"killPending" : <boolean>,
"numYields" : <number>,
"lockStats" : {
"timeLockedMicros" : {
"R" : <NumberLong()>,
"W" : <NumberLong()>,
"r" : <NumberLong()>,
"w" : <NumberLong()>
},
"timeAcquiringMicros" : {
"R" : <NumberLong()>,
"W" : <NumberLong()>,
"r" : <NumberLong()>,
"w" : <NumberLong()>
}
}
},
...
]
}
2.1. mongo Shell Methods 109
MongoDB Reference Manual, Release 2.6.4
Output Fields
currentOp.opid
The identier for the operation. You can pass this value to db.killOp() (page 120) in the mongo (page 580)
shell to terminate the operation.
Warning: Terminate running operations with extreme caution. Only use db.killOp() (page 120) to
terminate operations initiated by clients and do not terminate internal database operations.
currentOp.active
A boolean value specifying whether the operation has started. Value is true if the operation has started or
false if the operation is queued and waiting for a lock to run. active (page 110) may be true even if the
operation has yielded to another operation.
currentOp.secs_running
The duration of the operation in seconds. MongoDB calculates this value by subtracting the current time from
the start time of the operation.
Only appears if the operation is running, (i.e. if active (page 110) is true).
currentOp.microsecs_running
New in version 2.6.
The duration of the operation in microseconds. MongoDB calculates this value by subtracting the current time
from the start time of the operation.
Only appears if the operation is running, (i.e. if active (page 110) is true).
currentOp.op
A string that identies the type of operation. The possible values are:
"none"
"update"
"insert"
"query"
"getmore"
"remove"
"killcursors"
The "query" type includes operations that use the insert (page 245), update (page 249), and delete
(page 232) commands. Write operations that do not use the aforementioned write commands will show with the
appropriate "insert", "update", or "remove" value.
currentOp.ns
The namespace the operation targets. A namespace consists of the database name and the collection name
concatenated with a dot (.); i.e., "<database>.<collection>".
currentOp.insert
Contains the document to be inserted for operations with op (page 110) value of "insert". Only appears for
operations with op (page 110) value "insert".
Insert operations such as db.collection.insert() (page 53) that use the insert (page 245) command
will have op (page 110) value of "query".
currentOp.query
A document containing information on current operation if op (page 110) value is not "insert". query
(page 110) does not appear for op (page 110) of type "insert".
110 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Write operations that use the insert (page 245), update (page 249), and delete (page 232) commands
have op (page 110) value of "query" and the corresponding query (page 110) contains information on these
operations.
For example, the following query (page 110) eld contains information for an update operation:
"query" : {
"update" : "grades",
"updates" : [
{
"q" : {
"x" : {
"$gt" : 70
}
},
"u" : {
"$set" : {
"y" : 1
}
},
"multi" : true,
"upsert" : false
}
],
"ordered" : true
}
The document can be empty for op (page 110) types such as "getmore".
currentOp.planSummary
A string that contains the query plan to help debug slow queries.
currentOp.client
The IP address (or hostname) and the ephemeral port of the client connection where the operation originates. If
your inprog array has operations from many different clients, use this string to relate operations to clients.
For some commands, including findAndModify (page 237) and db.eval() (page 113), the client will be
0.0.0.0:0, rather than an actual client.
currentOp.desc
A description of the client. This string includes the connectionId (page 111).
currentOp.threadId
An identier for the thread that services the operation and its connection.
currentOp.connectionId
An identier for the connection where the operation originated.
currentOp.locks
New in version 2.2.
The locks (page 111) document reports by databases the types of locks the operation currently holds. The
possible lock types are:
R represents the global read lock,
W represents the global write lock,
r represents the database specic read lock, and
w represents the database specic write lock.
2.1. mongo Shell Methods 111
MongoDB Reference Manual, Release 2.6.4
currentOp.locks.^
^ (page 111) reports on the use of the global lock for the mongod (page 555) instance. All operations
must hold the global lock for some phases of operation.
currentOp.locks.^local
^local (page 112) reports on the lock for the local database. MongoDB uses the local database
for a number of operations, but the most frequent use of the local database is for the oplog used in
replication.
currentOp.locks.^<database>
locks.^<database> (page 112) reports on the lock state for the database that this operation targets.
currentOp.waitingForLock
Returns a boolean value. waitingForLock (page 112) is true if the operation is waiting for a lock and
false if the operation has the required lock.
currentOp.msg
The msg (page 112) provides a message that describes the status and progress of the operation. In the case of
indexing or mapReduce operations, the eld reports the completion percentage.
currentOp.progress
Reports on the progress of mapReduce or indexing operations. The progress (page 112) elds corresponds
to the completion percentage in the msg (page 112) eld. The progress (page 112) species the following
information:
currentOp.progress.done
Reports the number completed.
currentOp.progress.total
Reports the total number.
currentOp.killPending
Returns true if the operation is currently agged for termination. When the operation encounters its next safe
termination point, the operation will terminate.
currentOp.numYields
numYields (page 112) is a counter that reports the number of times the operation has yielded to allow other
operations to complete.
Typically, operations yield when they need access to data that MongoDB has not yet fully read into memory.
This allows other operations that have data in memory to complete quickly while MongoDB reads in data for
the yielding operation.
currentOp.lockStats
New in version 2.2.
The lockStats (page 112) document reects the amount of time the operation has spent both acquiring and
holding locks. lockStats (page 112) reports data on a per-lock type, with the following possible lock types:
R represents the global read lock,
W represents the global write lock,
r represents the database specic read lock, and
w represents the database specic write lock.
currentOp.timeLockedMicros
The timeLockedMicros (page 112) document reports the amount of time the operation has spent
holding a specic lock.
112 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
For operations that require more than one lock, like those that lock the local database to update the
oplog, then the values in this document can be longer than this value may be longer than the total length
of the operation (i.e. secs_running (page 110).)
currentOp.timeLockedMicros.R
Reports the amount of time in microseconds the operation has held the global read lock.
currentOp.timeLockedMicros.W
Reports the amount of time in microseconds the operation has held the global write lock.
currentOp.timeLockedMicros.r
Reports the amount of time in microseconds the operation has held the database specic read lock.
currentOp.timeLockedMicros.w
Reports the amount of time in microseconds the operation has held the database specic write lock.
currentOp.timeAcquiringMicros
The timeAcquiringMicros (page 113) document reports the amount of time the operation has spent
waiting to acquire a specic lock.
currentOp.timeAcquiringMicros.R
Reports the mount of time in microseconds the operation has waited for the global read lock.
currentOp.timeAcquiringMicros.W
Reports the mount of time in microseconds the operation has waited for the global write lock.
currentOp.timeAcquiringMicros.r
Reports the mount of time in microseconds the operation has waited for the database specic read
lock.
currentOp.timeAcquiringMicros.w
Reports the mount of time in microseconds the operation has waited for the database specic write
lock.
db.dropDatabase()
db.dropDatabase()
Removes the current database. Does not change the current database, so the insertion of any documents in this
database will allocate a fresh set of data les.
db.eval()
Denition
db.eval(function, arguments)
Provides the ability to run JavaScript code on the MongoDB server.
The helper db.eval() (page 113) in the mongo (page 580) shell wraps the eval (page 235) command.
Therefore, the helper method shares the characteristics and behavior of the underlying command with one ex-
ception: db.eval() (page 113) method does not support the nolock option.
The method accepts the following parameters:
param JavaScript function function A JavaScript function to execute.
param list arguments A list of arguments to pass to the JavaScript function. Omit if the function
does not take arguments.
The JavaScript function need not take any arguments, as in the rst example, or may optionally take arguments
as in the second:
2.1. mongo Shell Methods 113
MongoDB Reference Manual, Release 2.6.4
function () {
// ...
}
function (arg1, arg2) {
// ...
}
Behavior
Write Lock By default, db.eval() (page 113) takes a global write lock while evaluating the JavaScript function.
As a result, db.eval() (page 113) blocks all other read and write operations to the database while the db.eval()
(page 113) operation runs.
To prevent the taking of the global write lock while evaluating the JavaScript code, use the eval (page 235) command
with nolock set to true. nolock does not impact whether the operations within the JavaScript code take write
locks.
For long running db.eval() (page 113) operation, consider using either the eval command with nolock: true
or using other server side code execution options.
Sharded Data You can not use db.eval() (page 113) with sharded collections. In general, you should avoid
using db.eval() (page 113) in sharded clusters; nevertheless, it is possible to use db.eval() (page 113) with
non-sharded collections and databases stored in a sharded cluster.
Access Control Changed in version 2.6.
If authorization is enabled, you must have access to all actions on all resources in order to run db.eval() (page 113).
Providing such access is not recommended, but if your organization requires a user to run db.eval() (page 113),
create a role that grants anyAction on resource-anyresource. Do not assign this role to any other user.
JavaScript Engine Changed in version 2.4.
The V8 JavaScript engine, which became the default in 2.4, allows multiple JavaScript operations to execute at the
same time. Prior to 2.4, db.eval() (page 113) executed in a single thread.
Examples The following is an example of the db.eval() (page 113) method:
db.eval( function(name, incAmount) {
var doc = db.myCollection.findOne( { name : name } );
doc = doc || { name : name , num : 0 , total : 0 , avg : 0 };
doc.num++;
doc.total += incAmount;
doc.avg = doc.total / doc.num;
db.myCollection.save( doc );
return doc;
},
"eliot", 5 );
The db in the function refers to the current database.
114 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"eliot" is the argument passed to the function, and corresponds to the name argument.
5 is an argument to the function and corresponds to the incAmount eld.
If you want to use the servers interpreter, you must run db.eval() (page 113). Otherwise, the mongo (page 580)
shells JavaScript interpreter evaluates functions entered directly into the shell.
If an error occurs, db.eval() (page 113) throws an exception. The following is an example of an invalid function
that uses the variable x without declaring it as an argument:
db.eval( function() { return x + x; }, 3 );
The statement results in the following exception:
{
"errmsg" : "exception: JavaScript execution failed: ReferenceError: x is not defined near '{ return x + x; }' ",
"code" : 16722,
"ok" : 0
}
See also:
http://docs.mongodb.org/manualcore/server-side-javascript
db.fsyncLock()
db.fsyncLock()
Forces the mongod (page 555) to ush all pending write operations to the disk and locks the entire mongod
(page 555) instance to prevent additional writes until the user releases the lock with the db.fsyncUnlock()
(page 115) command. db.fsyncLock() (page 115) is an administrative command.
This command provides a simple wrapper around a fsync (page 328) database command with the following
syntax:
{ fsync: 1, lock: true }
This function locks the database and create a window for backup operations.
Important: db.fsyncLock() (page 115) may block reads, including those necessary to verify authentica-
tion. Such reads are necessary to establish new connections to a mongod (page 555) that enforces authorization
checks.
Warning: When calling db.fsyncLock() (page 115), ensure that the connection is kept open to allow
a subsequent call to db.fsyncUnlock() (page 115).
Closing the connection may make it difcult to release the lock.
db.fsyncUnlock()
db.fsyncUnlock()
Unlocks a mongod (page 555) instance to allow writes and reverses the operation of a db.fsyncLock()
(page 115) operation. Typically you will use db.fsyncUnlock() (page 115) following a database backup
operation.
db.fsyncUnlock() (page 115) is an administrative command.
2.1. mongo Shell Methods 115
MongoDB Reference Manual, Release 2.6.4
db.getCollection()
Description
db.getCollection(name)
Returns a collection name. This is useful for a collection whose name might interact with the shell itself, such
names that begin with _ or that mirror the database commands (page 208).
The db.getCollection() (page 116) method has the following parameter:
param string name The name of the collection.
db.getCollectionNames()
db.getCollectionNames()
Returns An array containing all collections in the existing database.
db.getLastError()
db.getLastError()
Changed in version 2.6: A new protocol for write operations (page 687) integrates write concerns with the write
operations, eliminating the need for a separate db.getLastError() (page 116) method. Write methods
now return the status of the write operation, including error information.
In previous versions, clients typically used the db.getLastError() (page 116) method in combination with
the write operations to ensure that the write succeeds.
Returns The last error message string.
Sets the level of write concern for conrming the success of write operations.
See
getLastError (page 243) and http://docs.mongodb.org/manualreference/write-concern
for all options, Write Concern for a conceptual overview, http://docs.mongodb.org/manualcore/write-operations
for information about all write operations in MongoDB.
db.getLastErrorObj()
db.getLastErrorObj()
Changed in version 2.6: A new protocol for write operations (page 687) integrates write concerns with the write
operations, eliminating the need for a separate db.getLastError() (page 116) method. Write methods
now return the status of the write operation, including error information.
In previous versions, clients typically used the db.getLastError() (page 116) method in combination with
the write operations to ensure that the write succeeds.
Returns A full document with status information.
See also:
Write Concern, http://docs.mongodb.org/manualreference/write-concern, and
replica-set-write-concern.
116 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.getMongo()
db.getMongo()
Returns The current database connection.
db.getMongo() (page 117) runs when the shell initiates. Use this command to test that the mongo
(page 580) shell has a connection to the proper database instance.
db.getName()
db.getName()
Returns the current database name.
db.getPrevError()
db.getPrevError()
Returns A status document, containing the errors.
Deprecated since version 1.6.
This output reports all errors since the last time the database received a resetError (page 248) (also
db.resetError() (page 124)) command.
This method provides a wrapper around the getPrevError (page 245) command.
db.getProlingLevel()
db.getProfilingLevel()
This method provides a wrapper around the database command profile (page 353) and returns the current
proling level.
Deprecated since version 1.8.4: Use db.getProfilingStatus() (page 117) for related functionality.
db.getProlingStatus()
db.getProfilingStatus()
Returns The current profile (page 353) level and slowOpThresholdMs setting.
db.getReplicationInfo()
Denition
db.getReplicationInfo()
Returns A document with the status of the replica status, using data polled from the oplog. Use
this output when diagnosing issues with replication.
2.1. mongo Shell Methods 117
MongoDB Reference Manual, Release 2.6.4
Output
db.getReplicationInfo.logSizeMB
Returns the total size of the oplog in megabytes. This refers to the total amount of space allocated to the oplog
rather than the current size of operations stored in the oplog.
db.getReplicationInfo.usedMB
Returns the total amount of space used by the oplog in megabytes. This refers to the total amount of space
currently used by operations stored in the oplog rather than the total amount of space allocated.
db.getReplicationInfo.errmsg
Returns an error message if there are no entries in the oplog.
db.getReplicationInfo.oplogMainRowCount
Only present when there are no entries in the oplog. Reports a the number of items or rows in the oplog (e.g. 0).
db.getReplicationInfo.timeDiff
Returns the difference between the rst and last operation in the oplog, represented in seconds.
Only present if there are entries in the oplog.
db.getReplicationInfo.timeDiffHours
Returns the difference between the rst and last operation in the oplog, rounded and represented in hours.
Only present if there are entries in the oplog.
db.getReplicationInfo.tFirst
Returns a time stamp for the rst (i.e. earliest) operation in the oplog. Compare this value to the last write
operation issued against the server.
Only present if there are entries in the oplog.
db.getReplicationInfo.tLast
Returns a time stamp for the last (i.e. latest) operation in the oplog. Compare this value to the last write operation
issued against the server.
Only present if there are entries in the oplog.
db.getReplicationInfo.now
Returns a time stamp that reects reecting the current time. The shell process generates this value, and the
datum may differ slightly from the server time if youre connecting from a remote host as a result. Equivalent
to Date() (page 197).
Only present if there are entries in the oplog.
db.getSiblingDB()
Denition
db.getSiblingDB(<database>)
param string database The name of a MongoDB database.
Returns A database object.
Used to return another database without modifying the db variable in the shell environment.
Example You can use db.getSiblingDB() (page 118) as an alternative to the use <database> helper. This
is particularly useful when writing scripts using the mongo (page 580) shell where the use helper is not available.
Consider the following sequence of operations:
118 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db = db.getSiblingDB('users')
db.active.count()
This operation sets the db object to point to the database named users, and then returns a count (page 26) of the
collection named active. You can create multiple db objects, that refer to different databases, as in the following
sequence of operations:
users = db.getSiblingDB('users')
records = db.getSiblingDB('records')
users.active.count()
users.active.findOne()
records.requests.count()
records.requests.findOne()
This operation creates two db objects referring to different databases (i.e. users and records) and then returns a
count (page 26) and an example document (page 42) fromone collection in that database (i.e. active and requests
respectively.)
db.help()
db.help()
Returns Text output listing common methods on the db object.
db.hostInfo()
db.hostInfo()
New in version 2.2.
Returns A document with information about the underlying system that the mongod (page 555) or
mongos (page 571) runs on. Some of the returned elds are only included on some platforms.
db.hostInfo() (page 119) provides a helper in the mongo (page 580) shell around the hostInfo
(page 345) The output of db.hostInfo() (page 119) on a Linux system will resemble the following:
{
"system" : {
"currentTime" : ISODate("<timestamp>"),
"hostname" : "<hostname>",
"cpuAddrSize" : <number>,
"memSizeMB" : <number>,
"numCores" : <number>,
"cpuArch" : "<identifier>",
"numaEnabled" : <boolean>
},
"os" : {
"type" : "<string>",
"name" : "<string>",
"version" : "<string>"
},
"extra" : {
"versionString" : "<string>",
"libcVersion" : "<string>",
"kernelVersion" : "<string>",
"cpuFrequencyMHz" : "<string>",
2.1. mongo Shell Methods 119
MongoDB Reference Manual, Release 2.6.4
"cpuFeatures" : "<string>",
"pageSize" : <number>,
"numPages" : <number>,
"maxOpenFiles" : <number>
},
"ok" : <return>
}
See hostInfo (page 346) for full documentation of the output of db.hostInfo() (page 119).
db.isMaster()
db.isMaster()
Returns A document that describes the role of the mongod (page 555) instance.
If the mongod (page 555) is a member of a replica set, then the ismaster (page 287) and secondary
(page 288) elds report if the instance is the primary or if it is a secondary member of the replica set.
See
isMaster (page 287) for the complete documentation of the output of db.isMaster() (page 120).
db.killOp()
Description
db.killOp(opid)
Terminates an operation as specied by the operation ID. To nd operations and their corresponding IDs, see
db.currentOp() (page 107).
The db.killOp() (page 120) method has the following parameter:
param number opid An operation ID.
Warning: Terminate running operations with extreme caution. Only use db.killOp() (page 120) to
terminate operations initiated by clients and do not terminate internal database operations.
db.listCommands()
db.listCommands()
Provides a list of all database commands. See the Database Commands (page 208) document for a more exten-
sive index of these options.
db.loadServerScripts()
db.loadServerScripts()
db.loadServerScripts() (page 120) loads all scripts in the system.js collection for the current
database into the mongo (page 580) shell session.
Documents in the system.js collection have the following prototype form:
120 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ _id : "<name>" , value : <function> } }
The documents in the system.js collection provide functions that your applications can use in any JavaScript
context with MongoDB in this database. These contexts include $where (page 404) clauses and mapReduce
(page 218) operations.
db.logout()
db.logout()
Ends the current authentication session. This function has no effect if the current session is not authenticated.
Note: If youre not logged in and using authentication, db.logout() (page 121) has no effect.
Changed in version 2.4: Because MongoDB now allows users dened in one database to have privileges on
another database, you must call db.logout() (page 121) while using the same database context that you
authenticated to.
If you authenticated to a database such as users or $external, you must issue db.logout() (page 121)
against this database in order to successfully log out.
Example
Use the use <database-name> helper in the interactive mongo (page 580) shell, or the following
db.getSiblingDB() (page 118) in the interactive shell or in mongo (page 580) shell scripts to change
the db object:
db = db.getSiblingDB('<database-name>')
When you have set the database context and db object, you can use the db.logout() (page 121) to log out
of database as in the following operation:
db.logout()
db.logout() (page 121) function provides a wrapper around the database command logout (page 262).
db.printCollectionStats()
db.printCollectionStats()
Provides a wrapper around the db.collection.stats() (page 69) method. Returns statistics from every
collection separated by three hyphen characters.
Note: The db.printCollectionStats() (page 121) in the mongo (page 580) shell does
not return JSON. Use db.printCollectionStats() (page 121) for manual inspection, and
db.collection.stats() (page 69) in scripts.
See also:
collStats (page 338)
db.printReplicationInfo()
db.printReplicationInfo()
Prints a formatted report of the status of a replica set from the perspective of the primary set member if run on
2.1. mongo Shell Methods 121
MongoDB Reference Manual, Release 2.6.4
the primary.
11
The displayed report formats the data returned by db.getReplicationInfo() (page 117).
Note: The db.printReplicationInfo() (page 121) in the mongo (page 580) shell does
not return JSON. Use db.printReplicationInfo() (page 121) for manual inspection, and
db.getReplicationInfo() (page 117) in scripts.
The output of db.printReplicationInfo() (page 121) is identical to that of
rs.printReplicationInfo() (page 174).
Output Example The following example is a sample output from the db.printReplicationInfo()
(page 121) method run on the primary:
configured oplog size: 192MB
log length start to end: 65422secs (18.17hrs)
oplog first event time: Mon Jun 23 2014 17:47:18 GMT-0400 (EDT)
oplog last event time: Tue Jun 24 2014 11:57:40 GMT-0400 (EDT)
now: Thu Jun 26 2014 14:24:39 GMT-0400 (EDT)
Output Fields db.printReplicationInfo() (page 121) formats and prints the data returned by
db.getReplicationInfo() (page 117):
congured oplog size Displays the db.getReplicationInfo.logSizeMB (page 118) value.
log length start to end Displays the db.getReplicationInfo.timeDiff (page 118) and
db.getReplicationInfo.timeDiffHours (page 118) values.
oplog rst event time Displays the db.getReplicationInfo.tFirst (page 118).
oplog last event time Displays the db.getReplicationInfo.tLast (page 118).
now Displays the db.getReplicationInfo.now (page 118).
See db.getReplicationInfo() (page 117) for description of the data.
db.printShardingStatus()
Denition
db.printShardingStatus()
Prints a formatted report of the sharding conguration and the information regarding existing chunks in a
sharded cluster.
Only use db.printShardingStatus() (page 122) when connected to a mongos (page 571) instance.
The db.printShardingStatus() (page 122) method has the following parameter:
param Boolean verbose If true, the method displays details of the document distribution across
chunks when you have 20 or more chunks.
See sh.status() (page 189) for details of the output.
Note: The db.printShardingStatus() (page 122) in the mongo (page 580) shell does not re-
turn JSON. Use db.printShardingStatus() (page 122) for manual inspection, and Cong Database
(page 647) in scripts.
See also:
11
If run on a secondary, the method calls db.printSlaveReplicationInfo() (page 123). See
db.printSlaveReplicationInfo() (page 123) for details.
122 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
sh.status() (page 189)
db.printSlaveReplicationInfo()
Denition
db.printSlaveReplicationInfo()
Returns a formatted report of the status of a replica set from the perspective of the secondary member of the set.
The output is identical to that of rs.printSlaveReplicationInfo() (page 174).
Output The following is example output from the rs.printSlaveReplicationInfo() (page 174) method
issued on a replica set with two secondary members:
source: m1.example.net:27017
syncedTo: Thu Apr 10 2014 10:27:47 GMT-0400 (EDT)
0 secs (0 hrs) behind the primary
source: m2.example.net:27017
syncedTo: Thu Apr 10 2014 10:27:47 GMT-0400 (EDT)
0 secs (0 hrs) behind the primary
Note: The db.printSlaveReplicationInfo() (page 123) in the mongo (page 580) shell does not re-
turn JSON. Use db.printSlaveReplicationInfo() (page 123) for manual inspection, and rs.status()
(page 177) in scripts.
A delayed member may show as 0 seconds behind the primary when the inactivity period on the primary is greater
than the slaveDelay value.
db.removeUser()
Deprecated since version 2.6: Use db.dropUser() (page 153) instead of db.removeUser() (page 155)
Denition
db.removeUser(username)
Removes the specied username from the database.
The db.removeUser() (page 155) method has the following parameter:
param string username The database username.
db.repairDatabase()
db.repairDatabase()
db.repairDatabase() (page 123) provides a wrapper around the database command repairDatabase
(page 332), and has the same effect as the run-time option mongod --repair option, limited to only the
current database. See repairDatabase (page 332) for full documentation.
2.1. mongo Shell Methods 123
MongoDB Reference Manual, Release 2.6.4
Behavior
Warning: During normal operations, only use the repairDatabase (page 332) command and wrappers
including db.repairDatabase() (page 123) in the mongo (page 580) shell and mongod --repair, to
compact database les and/or reclaim disk space. Be aware that these operations remove and do not save any
corrupt data during the repair process.
If you are trying to repair a replica set member, and you have access to an intact copy of your data (e.g. a
recent backup or an intact member of the replica set), you should restore from that intact copy, and not use
repairDatabase (page 332).
When using journaling, there is almost never any need to run repairDatabase (page 332). In the event of an
unclean shutdown, the server will be able to restore the data les to a pristine state automatically.
Changed in version 2.6: The db.repairDatabase() (page 123) is now available for secondary as well as primary
members of replica sets.
db.resetError()
db.resetError()
Deprecated since version 1.6.
Resets the error message returned by db.getPrevError (page 117) or getPrevError (page 245). Pro-
vides a wrapper around the resetError (page 248) command.
db.runCommand()
Denition
db.runCommand(command)
Provides a helper to run specied database commands (page 208). This is the preferred method to issue database
commands, as it provides a consistent interface between the shell and drivers.
param document,string command A database command, specied either in document form or as
a string. If specied as a string, db.runCommand() (page 124) transforms the string into a
document.
New in version 2.6: To specify a time limit in milliseconds, see
http://docs.mongodb.org/manualtutorial/terminate-running-operations.
Behavior db.runCommand() (page 124) runs the command in the context of the current database. Some com-
mands are only applicable in the context of the admin database, and you must change your db object to before
running these commands.
db.serverBuildInfo()
db.serverBuildInfo()
Provides a wrapper around the buildInfo (page 336) database command. buildInfo (page 336) returns a
document that contains an overview of parameters used to compile this mongod (page 555) instance.
db.serverCmdLineOpts()
db.serverCmdLineOpts()
Wraps the getCmdLineOpts (page 344) database command.
124 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Returns a document that reports on the arguments and conguration options used to start the mongod (page 555)
or mongos (page 571) instance.
See http://docs.mongodb.org/manualreference/configuration-options, mongod
(page 555), and mongos (page 570) for additional information on available MongoDB runtime options.
db.serverStatus()
db.serverStatus()
Returns a document that provides an overview of the database processs state.
This command provides a wrapper around the database command serverStatus (page 354).
Changed in version 2.4: In 2.4 you can dynamically suppress portions of the db.serverStatus()
(page 125) output, or include suppressed sections in a document passed to the db.serverStatus()
(page 125) method, as in the following example:
db.serverStatus( { repl: 0, indexCounters: 0, locks: 0 } )
db.serverStatus( { workingSet: 1, metrics: 0, locks: 0 } )
db.serverStatus() (page 125) includes all elds by default, except workingSet (page 367), by default.
Note: You may only dynamically include top-level elds from the serverStatus (page 354) document that are
not included by default. You can exclude any eld that db.serverStatus() (page 125) includes by default.
See also:
serverStatus (page 354) for complete documentation of the output of this function.
db.setProlingLevel()
Denition
db.setProfilingLevel(level, slowms)
Modies the current database proler level used by the database proling system to capture data about perfor-
mance. The method provides a wrapper around the database command profile (page 353).
param integer level Species a proling level, which is either 0 for no proling, 1 for only slow
operations, or 2 for all operations.
param integer slowms Sets the threshold in milliseconds for the prole to consider a query or op-
eration to be slow.
The level chosen can affect performance. It also can allow the server to write the contents of queries to the log,
which might have information security implications for your deployment.
Congure the slowOpThresholdMs option to set the threshold for the proler to consider a query slow.
Specify this value in milliseconds to override the default, 100ms.
mongod (page 555) writes the output of the database proler to the system.profile collection.
mongod (page 555) prints information about queries that take longer than the slowOpThresholdMs to the
log even when the database proler is not active.
db.shutdownServer()
db.shutdownServer()
Shuts down the current mongod (page 555) or mongos (page 571) process cleanly and safely.
2.1. mongo Shell Methods 125
MongoDB Reference Manual, Release 2.6.4
This operation fails when the current database is not the admin database.
This command provides a wrapper around the shutdown (page 334).
db.stats()
Description
db.stats(scale)
Returns statistics that reect the use state of a single database.
The db.stats() (page 126) method has the following parameter:
param number scale The scale at which to deliver results. Unless specied, this command returns
all data in bytes.
Returns A document with statistics reecting the database systems state. For an explanation of the
output, see dbStats (page 342).
The db.stats() (page 126) method is a wrapper around the dbStats (page 342) database command.
Example The following example converts the returned values to kilobytes:
db.stats(1024)
Note: The scale factor rounds values to whole numbers. This can produce unpredictable and unexpected results in
some situations.
db.upgradeCheck()
Denition
db.upgradeCheck(<document>)
New in version 2.6.
Performs a preliminary check for upgrade preparedness to 2.6. The helper, available in the 2.6 mongo (page 580)
shell, can run connected to either a 2.4 or a 2.6 server.
The method checks for:
documents with index keys longer than the index key limit (page 691),
documents with illegal field names (page 663),
collections without an _id index, and
indexes with invalid specications, such as an index key with an empty or illegal eld name.
The method can accept a document parameter which determine the scope of the check:
param document scope Document to limit the scope of the check to the specied collection in the
database.
Omit to perform the check on all collections in the database.
The optional scope document has the following form:
{
collection: <string>
}
126 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Additional 2.6 changes that affect compatibility with older versions require manual checks and intervention.
See Compatibility Changes in MongoDB 2.6 (page 691) for details.
See also:
db.upgradeCheckAllDBs() (page 128)
Behavior db.upgradeCheck() (page 126) performs collection scans and has an impact on performance. To
mitigate the performance impact:
For sharded clusters, congure to read from secondaries and run the command on the mongos (page 571).
For replica sets, run the command on the secondary members.
db.upgradeCheck() (page 126) can miss new data during the check when run on a live system with active write
operations.
For index validation, db.upgradeCheck() (page 126) only supports the check of version 1 indexes and skips the
check of version 0 indexes.
Required Access On systems running with authorization, a user must have access that includes the find
action on all collections, including the system collections (page 654).
Example The following example connects to a secondary running on localhost and runs
db.upgradeCheck() (page 126) against the employees collection in the records database. Because
the output from the method can be quite large, the example pipes the output to a le.
./mongo --eval "db.getMongo().setSlaveOk(); db.upgradeCheck( { collection: 'employees' } )" localhost/records | tee /tmp/upgradecheck.txt
Error Output The upgrade check can return the following errors when it encounters incompatibilities in your data:
Index Key Exceed Limit
Document Error: key for index '<indexName>' (<indexSpec>) too long on document: <doc>
To resolve, remove the document. Ensure that the query to remove the document does not specify a condition on the
invalid eld or eld.
Documents with Illegal Field Names
Document Error: document is no longer valid in 2.6 because <errmsg>: <doc>
To resolve, remove the document and re-insert with the appropriate corrections.
Index Specication Invalid
Index Error: invalid index spec for index '<indexName>': <indexSpec>
To resolve, remove the invalid index and recreate with a valid index specication.
Missing _id Index
Collection Error: lack of _id index on collection: <collectionName>
To resolve, create a unique index on _id.
2.1. mongo Shell Methods 127
MongoDB Reference Manual, Release 2.6.4
Warning Output
Warning: upgradeCheck only supports V1 indexes. Skipping index: <indexSpec>
To resolve, remove the invalid index and recreate the index omitting the version specication, or reindex the collection.
Reindex operation may be expensive for collections that have a large amount of data and/or a large number of indexes.
db.upgradeCheckAllDBs()
Denition
db.upgradeCheckAllDBs()
New in version 2.6.
Performs a preliminary check for upgrade preparedness to 2.6. The helper, available in the 2.6 mongo (page 580)
shell, can run connected to either a 2.4 or a 2.6 server in the admin database.
The method cycles through all the databases and checks for:
documents with index keys longer than the index key limit (page 691),
documents with illegal field names (page 663),
collections without an _id index, and
indexes with invalid specications, such as an index key with an empty or illegal eld name.
Additional 2.6 changes that affect compatibility with older versions require manual checks and intervention.
See Compatibility Changes in MongoDB 2.6 (page 691) for details.
See also:
db.upgradeCheck() (page 126)
Behavior db.upgradeCheckAllDBs() (page 128) performs collection scans and has an impact on perfor-
mance. To mitigate the performance impact:
For sharded clusters, congure to read from secondaries and run the command on the mongos (page 571).
For replica sets, run the command on the secondary members.
db.upgradeCheckAllDBs() (page 128) can miss new data during the check when run on a live system with
active write operations.
For index validation, db.upgradeCheckAllDBs() (page 128) only supports the check of version 1 indexes and
skips the check of version 0 indexes.
Required Access On systems running with authorization, a user must have access that includes the
listDatabases action on all databases and the find action on all collections, including the system collections
(page 654).
Example The following example connects to a secondary running on localhost and runs
db.upgradeCheckAllDBs() (page 128) against the admin database. Because the output from the method can
be quite large, the example pipes the output to a le.
./mongo --eval "db.getMongo().setSlaveOk(); db.upgradeCheckAllDBs();" localhost/admin | tee /tmp/upgradecheckalldbs.txt
Error Output The upgrade check can return the following errors when it encounters incompatibilities in your data:
128 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Index Key Exceed Limit
Document Error: key for index '<indexName>' (<indexSpec>) too long on document: <doc>
To resolve, remove the document. Ensure that the query to remove the document does not specify a condition on the
invalid eld or eld.
Documents with Illegal Field Names
Document Error: document is no longer valid in 2.6 because <errmsg>: <doc>
To resolve, remove the document and re-insert with the appropriate corrections.
Index Specication Invalid
Index Error: invalid index spec for index '<indexName>': <indexSpec>
To resolve, remove the invalid index and recreate with a valid index specication.
Missing _id Index
Collection Error: lack of _id index on collection: <collectionName>
To resolve, create a unique index on _id.
Warning Output
Warning: upgradeCheck only supports V1 indexes. Skipping index: <indexSpec>
To resolve, remove the invalid index and recreate the index omitting the version specication, or reindex the collection.
Reindex operation may be expensive for collections that have a large amount of data and/or a large number of indexes.
db.version()
db.version()
Returns The version of the mongod (page 555) or mongos (page 571) instance.
2.1.4 Query Plan Cache
Query Plan Cache Methods
The PlanCache methods are only accessible from a collections plan cache object. To retrieve the plan cache object,
use the db.collection.getPlanCache() (page 133) method.
2.1. mongo Shell Methods 129
MongoDB Reference Manual, Release 2.6.4
Name Description
PlanCache.clear()
(page 130)
Clears all the cached query plans for a collection. Accessible through the plan
cache object of a specic collection, i.e.
db.collection.getPlanCache().clear().
PlanCache.clearPlansByQuery()
(page 130)
Clears the cached query plans for the specied query shape. Accessible through the
plan cache object of a specic collection, i.e.
db.collection.getPlanCache().clearPlansByQuery()
PlanCache.getPlansByQuery()
(page 131)
Displays the cached query plans for the specied query shape. Accessible through
the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().getPlansByQuery().
PlanCache.help()
(page 132)
Displays the methods available for a collections query plan cache. Accessible
through the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().help().
PlanCache.listQueryShapes()
(page 132)
Displays the query shapes for which cached query plans exist. Accessible through
the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().listQueryShapes().
db.collection.getPlanCache()
(page 133)
Returns an interface to access the query plan cache object and associated PlanCache
methods for a collection.
PlanCache.clear()
Denition
PlanCache.clear()
Removes all cached query plans for a collection.
The method is only available from the plan cache object (page 133) of a specic collection; i.e.
db.collection.getPlanCache().clear()
For example, to clear the cache for the orders collection:
db.orders.getPlanCache().clear()
Required Access On systems running with authorization, a user must have access that includes the
planCacheWrite action.
See also:
db.collection.getPlanCache() (page 133)
PlanCache.clearPlansByQuery() (page 130)
PlanCache.clearPlansByQuery()
Denition
PlanCache.clearPlansByQuery(<query>, <projection>, <sort>)
Clears the cached query plans for the specied query shape.
The method is only available from the plan cache object (page 133) of a specic collection; i.e.
db.collection.getPlanCache().clearPlansByQuery( <query>, <projection>, <sort> )
The PlanCache.clearPlansByQuery() (page 130) method accepts the following parameters:
130 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
param document query The query predicate of the query shape. Only the structure of the predicate,
including the eld names, are signicant to the shape; the values in the query predicate are
insignicant.
param document projection The projection associated with the query shape. Required if specify-
ing the sort parameter.
param document sort The sort associated with the query shape.
To see the query shapes for which cached query plans exist, use the PlanCache.listQueryShapes()
(page 132) method.
Required Access On systems running with authorization, a user must have access that includes the
planCacheWrite action.
Example If a collection orders has the following query shape:
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
}
The following operation removes the query plan cached for the shape:
db.orders.getPlanCache().clearPlansByQuery(
{ "qty" : { "$gt" : 10 } },
{ },
{ "ord_date" : 1 }
)
See also:
db.collection.getPlanCache() (page 133)
PlanCache.listQueryShapes() (page 132)
PlanCache.clear() (page 130)
PlanCache.getPlansByQuery()
Denition
PlanCache.getPlansByQuery(<query>, <projection>, <sort>)
Displays the cached query plans for the specied query shape.
The query optimizer only caches the plans for those query shapes that can have more than one viable plan.
The method is only available from the plan cache object (page 133) of a specic collection; i.e.
db.collection.getPlanCache().getPlansByQuery( <query>, <projection>, <sort> )
The PlanCache.getPlansByQuery() (page 131) method accepts the following parameters:
param document query The query predicate of the query shape. Only the structure of the predicate,
including the eld names, are signicant to the shape; the values in the query predicate are
insignicant.
param document projection The projection associated with the query shape. Required if specify-
ing the sort parameter.
2.1. mongo Shell Methods 131
MongoDB Reference Manual, Release 2.6.4
param document sort The sort associated with the query shape.
Returns Array of cached query plans for a query shape.
To see the query shapes for which cached query plans exist, use the PlanCache.listQueryShapes()
(page 132) method.
Required Access On systems running with authorization, a user must have access that includes the
planCacheRead action.
Example If a collection orders has the following query shape:
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
}
The following operation displays the query plan cached for the shape:
db.orders.getPlanCache().getPlansByQuery(
{ "qty" : { "$gt" : 10 } },
{ },
{ "ord_date" : 1 }
)
See also:
db.collection.getPlanCache() (page 133)
PlanCache.listQueryShapes() (page 132)
PlanCache.help() (page 132)
PlanCache.help()
Denition
PlanCache.help()
Displays the methods available to view and modify a collections query plan cache.
The method is only available from the plan cache object (page 133) of a specic collection; i.e.
db.collection.getPlanCache().help()
See also:
db.collection.getPlanCache() (page 133)
PlanCache.listQueryShapes()
Denition
PlanCache.listQueryShapes()
Displays the query shapes for which cached query plans exist.
The query optimizer only caches the plans for those query shapes that can have more than one viable plan.
The method is only available from the plan cache object (page 133) of a specic collection; i.e.
132 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.getPlanCache().listQueryShapes()
Returns Array of query shape documents.
The method wraps the planCacheListQueryShapes (page 258) command.
Required Access On systems running with authorization, a user must have access that includes the
planCacheRead action.
Example The following returns the query shapes that have cached plans for the orders collection:
db.orders.getPlanCache().listQueryShapes()
The method returns an array of the query shapes currently in the cache. In the example, the orders collection had
cached query plans associated with the following shapes:
[
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
},
{
"query" : { "$or" :
[
{ "qty" : { "$gt" : 15 }, "item" : "xyz123" },
{ "status" : "A" }
]
},
"sort" : { },
"projection" : { }
},
{
"query" : { "$or" : [ { "qty" : { "$gt" : 15 } }, { "status" : "A" } ] },
"sort" : { },
"projection" : { }
}
]
See also:
db.collection.getPlanCache() (page 133)
PlanCache.getPlansByQuery() (page 131)
PlanCache.help() (page 132)
planCacheListQueryShapes (page 258)
db.collection.getPlanCache()
Denition
db.collection.getPlanCache()
Returns an interface to access the query plan cache for a collection. The interface provides methods to view and
clear the query plan cache.
Returns Interface to access the query plan cache.
2.1. mongo Shell Methods 133
MongoDB Reference Manual, Release 2.6.4
The query optimizer only caches the plans for those query shapes that can have more than one viable plan.
Methods The following methods are available through the interface:
Name Description
PlanCache.help()
(page 132)
Displays the methods available for a collections query plan cache. Accessible
through the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().help().
PlanCache.listQueryShapes()
(page 132)
Displays the query shapes for which cached query plans exist. Accessible through
the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().listQueryShapes().
PlanCache.getPlansByQuery()
(page 131)
Displays the cached query plans for the specied query shape. Accessible through
the plan cache object of a specic collection, i.e.
db.collection.getPlanCache().getPlansByQuery().
PlanCache.clearPlansByQuery()
(page 130)
Clears the cached query plans for the specied query shape. Accessible through the
plan cache object of a specic collection, i.e.
db.collection.getPlanCache().clearPlansByQuery()
PlanCache.clear()
(page 130)
Clears all the cached query plans for a collection. Accessible through the plan
cache object of a specic collection, i.e.
db.collection.getPlanCache().clear().
2.1.5 Bulk Write Operation
Bulk Operation Methods
New in version 2.6.
Name Description
Bulk() (page 135) Bulk operations builder.
Bulk.execute()
(page 136)
Executes a list of operations in bulk.
Bulk.find() (page 138) Species the query condition for an update or a remove operation.
Bulk.find.remove()
(page 138)
Adds a multiple document remove operation to a list of operations.
Bulk.find.removeOne()
(page 139)
Adds a single document remove operation to a list of operations.
Bulk.find.replaceOne()
(page 139)
Adds a single document replacement operation to a list of operations.
Bulk.find.update()
(page 140)
Adds a multi update operation to a list of operations.
Bulk.find.updateOne()
(page 141)
Adds a single document update operation to a list of operations.
Bulk.find.upsert()
(page 142)
Species upsert: true for an update operation.
Bulk.getOperations()
(page 145)
Returns an array of write operations executed in the Bulk() (page 135)
operations object.
Bulk.insert()
(page 146)
Adds an insert operation to a list of operations.
Bulk.toString()
(page 147)
Returns the Bulk.tojson() (page 147) results as a string.
Bulk.tojson()
(page 147)
Returns a JSON document that contains the number of operations and batches in
the Bulk() (page 135) operations object.
134 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Bulk()
Description
Bulk()
New in version 2.6.
Bulk operations builder used to construct a list of write operations to perform in bulk for a single collection. To
instantiate the builder, use either the db.collection.initializeOrderedBulkOp() (page 51) or the
db.collection.initializeUnorderedBulkOp() (page 52) method.
Ordered and Unordered Bulk Operations The builder can construct the list of operations as ordered or unordered.
Ordered Operations With an ordered operations list, MongoDB executes the write operations in the list serially.
If an error occurs during the processing of one of the write operations, MongoDB will return without processing any
remaining write operations in the list.
Use db.collection.initializeOrderedBulkOp() (page 51) to create a builder for an ordered list of write
commands.
When executing an ordered (page 51) list of operations, MongoDB groups the operations by the operation
type (page 146) and contiguity; i.e. contiguous operations of the same type are grouped together. For example, if an
ordered list has two insert operations followed by an update operation followed by another insert operation, MongoDB
groups the operations into three separate groups: rst group contains the two insert operations, second group contains
the update operation, and the third group contains the last insert operation. This behavior is subject to change in future
versions.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
Executing an ordered (page 51) list of operations on a sharded collection will generally be slower than executing an
unordered (page 52) list since with an ordered list, each operation must wait for the previous operation to nish.
Unordered Operations With an unordered operations list, MongoDB can execute in parallel, as well as in a nonde-
terministic order, the write operations in the list. If an error occurs during the processing of one of the write operations,
MongoDB will continue to process remaining write operations in the list.
Use db.collection.initializeUnorderedBulkOp() (page 52) to create a builder for an unordered list
of write commands.
When executing an unordered (page 52) list of operations, MongoDB groups the operations. With an unordered
bulk operation, the operations in the list may be reordered to increase performance. As such, applications should not
depend on the ordering when performing unordered (page 52) bulk operations.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
2.1. mongo Shell Methods 135
MongoDB Reference Manual, Release 2.6.4
Methods The Bulk() (page 135) builder has the following methods:
Name Description
Bulk.insert()
(page 146)
Adds an insert operation to a list of operations.
Bulk.find() (page 138) Species the query condition for an update or a remove operation.
Bulk.find.removeOne()
(page 139)
Adds a single document remove operation to a list of operations.
Bulk.find.remove()
(page 138)
Adds a multiple document remove operation to a list of operations.
Bulk.find.replaceOne()
(page 139)
Adds a single document replacement operation to a list of operations.
Bulk.find.updateOne()
(page 141)
Adds a single document update operation to a list of operations.
Bulk.find.update()
(page 140)
Adds a multi update operation to a list of operations.
Bulk.find.upsert()
(page 142)
Species upsert: true for an update operation.
Bulk.execute()
(page 136)
Executes a list of operations in bulk.
Bulk.getOperations()
(page 145)
Returns an array of write operations executed in the Bulk() (page 135)
operations object.
Bulk.tojson()
(page 147)
Returns a JSON document that contains the number of operations and batches in
the Bulk() (page 135) operations object.
Bulk.toString()
(page 147)
Returns the Bulk.tojson() (page 147) results as a string.
Bulk.execute()
Description
Bulk.execute()
New in version 2.6.
Executes the list of operations built by the Bulk() (page 135) operations builder.
Bulk.execute() (page 136) accepts the following parameter:
param document writeConcern Write concern document for the bulk operation as a whole. Omit
to use default. For a standalone mongod (page 555) server, the write concern defaults to { w:
1 }. With a replica set, the default write concern for a mongod (page 555) server is set as a
replica set conguration option.
Returns A BulkWriteResult (page 196) object that contains the status of the operation.
After execution, you cannot re-execute the Bulk() (page 135) object without reini-
tializing. See db.collection.initializeUnorderedBulkOp() (page 52) and
db.collection.initializeOrderedBulkOp() (page 51).
Behavior
Ordered Operations When executing an ordered (page 51) list of operations, MongoDBgroups the operations by
the operation type (page 146) and contiguity; i.e. contiguous operations of the same type are grouped together.
For example, if an ordered list has two insert operations followed by an update operation followed by another insert
operation, MongoDB groups the operations into three separate groups: rst group contains the two insert operations,
136 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
second group contains the update operation, and the third group contains the last insert operation. This behavior is
subject to change in future versions.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
Executing an ordered (page 51) list of operations on a sharded collection will generally be slower than executing an
unordered (page 52) list since with an ordered list, each operation must wait for the previous operation to nish.
Unordered Operations When executing an unordered (page 52) list of operations, MongoDB groups the opera-
tions. With an unordered bulk operation, the operations in the list may be reordered to increase performance. As such,
applications should not depend on the ordering when performing unordered (page 52) bulk operations.
Each group of operations can have at most 1000 operations (page 663). If a group exceeds this limit
(page 663), MongoDB will divide the group into smaller groups of 1000 or less. For example, if the bulk opera-
tions list consists of 2000 insert operations, MongoDB creates 2 groups, each with 1000 operations.
The sizes and grouping mechanics are internal performance details and are subject to change in future versions.
To see how the operations are grouped for a bulk operation execution, call Bulk.getOperations() (page 145)
after the execution.
Example The following initializes a Bulk() (page 135) operations builder on the items collection, adds a series
of insert operations, and executes the operations:
var bulk = db.items.initializeOrderedBulkOp();
bulk.insert( { item: "abc123", status: "A", defaultQty: 500, points: 5 } );
bulk.insert( { item: "ijk123", status: "A", defaultQty: 100, points: 10 } );
bulk.find( { status: "D" } ).removeOne();
bulk.find( { status: "D" } ).update( { $set: { points: 0 } } );
bulk.execute();
The operation returns the following BulkWriteResult() (page 196) object:
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 2,
"nUpserted" : 0,
"nMatched" : 3,
"nModified" : 3,
"nRemoved" : 1,
"upserted" : [ ]
})
For details on the return object, see BulkWriteResult() (page 196). For details on the batches executed, see
Bulk.getOperations() (page 145).
See
Bulk() (page 135) for a listing of methods available for bulk operations.
2.1. mongo Shell Methods 137
MongoDB Reference Manual, Release 2.6.4
Bulk.nd()
Description
Bulk.find(<query>)
New in version 2.6.
Species a query condition for an update or a remove operation.
Bulk.find() (page 138) accepts the following parameter:
param document query Species a query condition using Query Selectors (page 386) to select
documents for an update or a remove operation.
With update operations, the sum of the query document and the update document must be less
than or equal to the maximum BSON document size (page 658).
With remove operations, the query document must be less than or equal to the maximum BSON
document size (page 658).
Use Bulk.find() (page 138) with the following write operations:
Bulk.find.removeOne() (page 139)
Bulk.find.remove() (page 138)
Bulk.find.replaceOne() (page 139)
Bulk.find.updateOne() (page 141)
Bulk.find.update() (page 140)
Example The following example initializes a Bulk() (page 135) operations builder for the items collection and
adds a remove operation and an update operation to the list of operations. The remove operation and the update
operation use the Bulk.find() (page 138) method to specify a condition for their respective actions:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "D" } ).remove();
bulk.find( { status: "P" } ).update( { $set: { points: 0 } } )
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.execute() (page 136)
Bulk.nd.remove()
Description
Bulk.find.remove()
New in version 2.6.
Adds a remove operation to a bulk operations list. Use the Bulk.find() (page 138) method to spec-
ify the condition that determines which documents to remove. The Bulk.find.remove() (page 138)
method removes all matching documents in the collection. To limit the remove to a single document, see
Bulk.find.removeOne() (page 139).
138 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example The following example initializes a Bulk() (page 135) operations builder for the items collection and
adds a remove operation to the list of operations. The remove operation removes all documents in the collection where
the status equals "D":
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "D" } ).remove();
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.find.removeOne() (page 139)
Bulk.execute() (page 136)
Bulk.nd.removeOne()
Description
Bulk.find.removeOne()
New in version 2.6.
Adds a single document remove operation to a bulk operations list. Use the Bulk.find() (page 138)
method to specify the condition that determines which document to remove. The Bulk.find.removeOne()
(page 139) limits the removal to one document. To remove multiple documents, see Bulk.find.remove()
(page 138).
Example The following example initializes a Bulk() (page 135) operations builder for the items collection and
adds two Bulk.find.removeOne() (page 139) operations to the list of operations.
Each remove operation removes just one document: one document with the status equal to "D" and another
document with the status equal to "P".
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "D" } ).removeOne();
bulk.find( { status: "P" } ).removeOne();
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.find.remove() (page 138)
Bulk.execute() (page 136)
All Bulk Methods (page 136)
Bulk.nd.replaceOne()
Description
2.1. mongo Shell Methods 139
MongoDB Reference Manual, Release 2.6.4
Bulk.find.replaceOne(<document>)
New in version 2.6.
Adds a single document replacement operation to a bulk operations list. Use the Bulk.find()
(page 138) method to specify the condition that determines which document to replace. The
Bulk.find.replaceOne() (page 139) method limits the replacement to a single document.
Bulk.find.replaceOne() (page 139) accepts the following parameter:
param document replacement A replacement document that completely replaces the existing doc-
ument. Contains only eld and value pairs.
The sum of the associated <query> document from the Bulk.find() (page 138) and the
replacement document must be less than or equal to the maximum BSON document size
(page 658).
To specify an upsert for this operation, see Bulk.find.upsert() (page 142).
Example The following example initializes a Bulk() (page 135) operations builder for the items collection, and
adds various replaceOne (page 139) operations to the list of operations.
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { item: "abc123" } ).replaceOne( { item: "abc123", status: "P", points: 100 } );
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.execute() (page 136)
All Bulk Methods (page 136)
Bulk.nd.update()
Description
Bulk.find.update(<update>)
New in version 2.6.
Adds a multi update operation to a bulk operations list. The method updates specic elds in existing docu-
ments.
Use the Bulk.find() (page 138) method to specify the condition that determines which documents to up-
date. The Bulk.find.update() (page 140) method updates all matching documents. To specify a single
document update, see Bulk.find.updateOne() (page 141).
Bulk.find.update() (page 140) accepts the following parameter:
param document update Species the elds to update. Only contains update operator (page 429)
expressions.
The sum of the associated <query> document from the Bulk.find() (page 138) and
the update document must be less than or equal to the maximum BSON document size
(page 658).
140 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
To specify upsert: true for this operation, see Bulk.find.upsert() (page 142). With
Bulk.find.upsert() (page 142), if no documents match the Bulk.find() (page 138) query condi-
tion, the update operation inserts only a single document.
Example The following example initializes a Bulk() (page 135) operations builder for the items collection, and
adds various multi update operations to the list of operations.
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "D" } ).update( { $set: { status: "I", points: "0" } } );
bulk.find( { item: null } ).update( { $set: { item: "TBD" } } );
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.find.updateOne() (page 141)
Bulk.execute() (page 136)
All Bulk Methods (page 136)
Bulk.nd.updateOne()
Description
Bulk.find.updateOne(<update>)
New in version 2.6.
Adds a single document update operation to a bulk operations list. The operation can either replace an existing
document or update specic elds in an existing document.
Use the Bulk.find() (page 138) method to specify the condition that determines which document to update.
The Bulk.find.updateOne() (page 141) method limits the update or replacement to a single document.
To update multiple documents, see Bulk.find.update() (page 140).
Bulk.find.updateOne() (page 141) accepts the following parameter:
param document update An update document that updates specic elds or a replacement docu-
ment that completely replaces the existing document.
An update document only contains update operator (page 429) expressions. A replacement
document contains only eld and value pairs.
The sum of the associated <query> document from the Bulk.find() (page 138) and the
update/replacement document must be less than or equal to the maximum BSON document
size.
To specify an upsert: true for this operation, see Bulk.find.upsert() (page 142).
Behavior
Update Specic Fields If the <update> document contains only update operator (page 429) expressions, as in:
2.1. mongo Shell Methods 141
MongoDB Reference Manual, Release 2.6.4
{
$set: { status: "D" },
points: { $inc: 2 }
}
Then, Bulk.find.updateOne() (page 141) updates only the corresponding elds, status and points, in the
document.
Replace a Document If the <update> document contains only field:value expressions, as in:
{
item: "TBD",
points: 0,
inStock: true,
status: "I"
}
Then, Bulk.find.updateOne() (page 141) replaces the matching document with the <update> document
with the exception of the _id eld. The Bulk.find.updateOne() (page 141) method does not replace the _id
value.
Example The following example initializes a Bulk() (page 135) operations builder for the items collection, and
adds various updateOne (page 141) operations to the list of operations.
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "D" } ).updateOne( { $set: { status: "I", points: "0" } } );
bulk.find( { item: null } ).updateOne(
{
item: "TBD",
points: 0,
inStock: true,
status: "I"
}
);
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.find.update() (page 140)
Bulk.execute() (page 136)
All Bulk Methods (page 136)
Bulk.nd.upsert()
Description
Bulk.find.upsert()
New in version 2.6.
Sets the upsert option to true for an update or a replacement operation and has the following syntax:
142 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Bulk.find(<query>).upsert().update(<update>);
Bulk.find(<query>).upsert().updateOne(<update>);
Bulk.find(<query>).upsert().replaceOne(<replacement>);
With the upsert option set to true, if no matching documents exist for the Bulk.find() (page 138)
condition, then the update or the replacement operation performs an insert. If a matching document does exist,
then the update or replacement operation performs the specied update or replacement.
Use Bulk.find.upsert() (page 142) with the following write operations:
Bulk.find.replaceOne() (page 139)
Bulk.find.updateOne() (page 141)
Bulk.find.update() (page 140)
Behavior The following describe the insert behavior of various write operations when used in conjunction with
Bulk.find.upsert() (page 142).
Insert for Bulk.find.replaceOne() The Bulk.find.replaceOne() (page 139) method accepts, as its
parameter, a replacement document that only contains eld and value pairs:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { item: "abc123" } ).upsert().replaceOne(
{
item: "abc123",
status: "P",
points: 100,
}
);
bulk.execute();
If the replacement operation with the Bulk.find.upsert() (page 142) option performs an insert, the inserted
document is the replacement document. If the replacement document does not specify an _id eld, MongoDB adds
the _id eld:
{
"_id" : ObjectId("52ded3b398ca567f5c97ac9e"),
"item" : "abc123",
"status" : "P",
"points" : 100
}
Insert for Bulk.find.updateOne() The Bulk.find.updateOne() (page 141) method accepts, as its
parameter, an <update> document that contains only eld and value pairs or only update operator (page 429)
expressions.
Field and Value Pairs If the <update> document contains only eld and value pairs:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "P" } ).upsert().updateOne(
{
item: "TBD",
points: 0,
inStock: true,
status: "I"
2.1. mongo Shell Methods 143
MongoDB Reference Manual, Release 2.6.4
}
);
bulk.execute();
Then, if the update operation with the Bulk.find.upsert() (page 142) option performs an insert, the inserted
document is the <update> document. If the update document does not specify an _id eld, MongoDB adds the
_id eld:
{
"_id" : ObjectId("52ded5a898ca567f5c97ac9f"),
"item" : "TBD",
"points" : 0,
"inStock" : true,
"status" : "I"
}
Update Operator Expressions If the <update> document contains contains only update operator (page 429)
expressions:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "P", item: null } ).upsert().updateOne(
{
$setOnInsert: { defaultQty: 0, inStock: true },
$currentDate: { lastModified: true },
$set: { points: "0" }
}
);
bulk.execute();
Then, if the update operation with the Bulk.find.upsert() (page 142) option performs an insert, the update
operation inserts a document with eld and values from the <query> document of the Bulk.find() (page 138)
method and then applies the specied update from the <update> document:
{
"_id" : ObjectId("52ded68c98ca567f5c97aca0"),
"item" : null,
"status" : "P",
"defaultQty" : 0,
"inStock" : true,
"lastModified" : ISODate("2014-01-21T20:20:28.786Z"),
"points" : "0"
}
If neither the <query> document nor the <update> document species an _id eld, MongoDB adds the _id
eld.
Insert for Bulk.find.update() When using upsert() (page 142) with the multiple document update
method Bulk.find.update() (page 140), if no documents match the query condition, the update operation in-
serts a single document.
The Bulk.find.update() (page 140) method accepts, as its parameter, an <update> document that contains
only update operator (page 429) expressions:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.find( { status: "P" } ).upsert().update(
{
$setOnInsert: { defaultQty: 0, inStock: true },
144 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
$currentDate: { lastModified: true },
$set: { status: "I", points: "0" }
}
);
bulk.execute();
Then, if the update operation with the Bulk.find.upsert() (page 142) option performs an insert, the update
operation inserts a single document with the elds and values from the <query> document of the Bulk.find()
(page 138) method and then applies the specied update from the <update> document:
{
"_id": ObjectId("52ded81a98ca567f5c97aca1"),
"status": "I",
"defaultQty": 0,
"inStock": true,
"lastModified": ISODate("2014-01-21T20:27:06.691Z"),
"points": "0"
}
If neither the <query> document nor the <update> document species an _id eld, MongoDB adds the _id
eld.
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.find() (page 138)
Bulk.execute() (page 136)
All Bulk Methods (page 136)
Bulk.getOperations()
Bulk.getOperations()
New in version 2.6.
Returns an array of write operations executed through Bulk.execute() (page 136). The returned write
operations are in groups as determined by MongoDB for execution. For information on how MongoDB groups
the list of bulk write operations, see Bulk.execute() Behavior (page 136).
Only use Bulk.getOperations() (page 145) after a Bulk.execute() (page 136). Calling
Bulk.getOperations() (page 145) before you call Bulk.execute() (page 136) will result in an in-
complete list.
Example The following initializes a Bulk() (page 135) operations builder on the items collection, adds a series
of write operations, executes the operations, and then calls getOperations() (page 145) on the bulk builder
object:
var bulk = db.items.initializeUnorderedBulkOp();
for (var i = 1; i <= 1500; i++) {
bulk.insert( { x: i } );
}
bulk.execute();
bulk.getOperations();
2.1. mongo Shell Methods 145
MongoDB Reference Manual, Release 2.6.4
The getOperations() (page 145) method returns an array with the operations executed. The output shows that
MongoDB divided the operations into 2 groups, one with 1000 operations and one with 500. For information on how
MongoDB groups the list of bulk write operations, see Bulk.execute() Behavior (page 136)
Although the method returns all 1500 operations in the returned array, this page omits some of the results for brevity.
[
{
"originalZeroIndex" : 0,
"batchType" : 1,
"operations" : [
{ "_id" : ObjectId("53a8959f1990ca24d01c6165"), "x" : 1 },
... // Content omitted for brevity
{ "_id" : ObjectId("53a8959f1990ca24d01c654c"), "x" : 1000 }
]
},
{
"originalZeroIndex" : 1000,
"batchType" : 1,
"operations" : [
{ "_id" : ObjectId("53a8959f1990ca24d01c654d"), "x" : 1001 },
... // Content omitted for brevity
{ "_id" : ObjectId("53a8959f1990ca24d01c6740"), "x" : 1500 }
]
}
]
Returned Fields The array contains documents with the following elds:
originalZeroIndex
Species the order in which the operation was added to the bulk operations builder, based on a zero index; e.g.
rst operation added to the bulk operations builder will have originalZeroIndex (page 146) value of 0.
batchType
Species the write operations type.
batchType Operation
1 Insert
2 Update
3 Remove
operations
Array of documents that contain the details of the operation.
See also:
Bulk() (page 135) and Bulk.execute() (page 136).
Bulk.insert()
Description
Bulk.insert(<document>)
New in version 2.6.
146 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Adds an insert operation to a bulk operations list.
Bulk.insert() (page 146) accepts the following parameter:
param document doc Document to insert. The size of the document must be less than or equal to
the maximum BSON document size (page 658).
Example The following initializes a Bulk() (page 135) operations builder for the items collection and adds a
series of insert operations to add multiple documents:
var bulk = db.items.initializeUnorderedBulkOp();
bulk.insert( { item: "abc123", defaultQty: 100, status: "A", points: 100 } );
bulk.insert( { item: "ijk123", defaultQty: 200, status: "A", points: 200 } );
bulk.insert( { item: "mop123", defaultQty: 0, status: "P", points: 0 } );
bulk.execute();
See also:
db.collection.initializeUnorderedBulkOp() (page 52)
db.collection.initializeOrderedBulkOp() (page 51)
Bulk.execute() (page 136)
Bulk.toString()
Bulk.toString()
New in version 2.6.
Returns as a string a JSON document that contains the number of operations and batches in the Bulk()
(page 135) object.
Example The following initializes a Bulk() (page 135) operations builder on the items collection, adds a series
of write operations, and calls Bulk.toString() (page 147) on the bulk builder object.
var bulk = db.items.initializeOrderedBulkOp();
bulk.insert( { item: "abc123", status: "A", defaultQty: 500, points: 5 } );
bulk.insert( { item: "ijk123", status: "A", defaultQty: 100, points: 10 } );
bulk.find( { status: "D" } ).removeOne();
bulk.toString();
The Bulk.toString() (page 147) returns the following JSON document
{ nInsertOps : 2, nUpdateOps : 0, nRemoveOps : 1, nBatches : 2 }
See also:
Bulk() (page 135)
Bulk.tojson()
Bulk.tojson()
New in version 2.6.
Returns a JSON document that contains the number of operations and batches in the Bulk() (page 135) object.
2.1. mongo Shell Methods 147
MongoDB Reference Manual, Release 2.6.4
Example The following initializes a Bulk() (page 135) operations builder on the items collection, adds a series
of write operations, and calls Bulk.tojson() (page 147) on the bulk builder object.
var bulk = db.items.initializeOrderedBulkOp();
bulk.insert( { item: "abc123", status: "A", defaultQty: 500, points: 5 } );
bulk.insert( { item: "ijk123", status: "A", defaultQty: 100, points: 10 } );
bulk.find( { status: "D" } ).removeOne();
bulk.tojson();
The Bulk.tojson() (page 147) returns the following JSON document
{ nInsertOps : 2, nUpdateOps : 0, nRemoveOps : 1, nBatches : 2 }
See also:
Bulk() (page 135)
2.1.6 User Management
User Management Methods
Name Description
db.addUser() (page 148) Deprecated. Adds a user to a database, and allows administrators to
congure the users privileges.
db.changeUserPassword()
(page 150)
Changes an existing users password.
db.createUser() (page 150) Creates a new user.
db.dropAllUsers()
(page 152)
Deletes all users associated with a database.
db.dropUser() (page 153) Removes a single user.
db.getUser() (page 154) Returns information about the specied user.
db.getUsers() (page 154) Returns information about all users associated with a database.
db.grantRolesToUser()
(page 154)
Grants a role and its privileges to a user.
db.removeUser() (page 155) Deprecated. Removes a user from a database.
db.revokeRolesFromUser()
(page 156)
Removes a role from a user.
db.updateUser() (page 157) Updates user data.
db.addUser()
Deprecated since version 2.6: Use db.createUser() (page 150) and db.updateUser() (page 157) instead of
db.addUser() (page 148) to add users to MongoDB.
In 2.6, MongoDB introduced a new model for user credentials and privileges, as described in
http://docs.mongodb.org/manualcore/security-introduction. To use db.addUser()
(page 148) on MongoDB 2.4, see db.addUser() in the version 2.4 of the MongoDB Manual
12
.
Denition
db.addUser(document)
Adds a new user on the database where you run the method. The db.addUser() (page 148) method takes a
user document as its argument:
12
http://docs.mongodb.org/v2.4/reference/method/db.addUser
148 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.addUser(<user document>)
Specify a document that resembles the following as an argument to db.addUser() (page 148):
{ user: "<name>",
pwd: "<cleartext password>",
customData: { <any information> },
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
The db.addUser() (page 148) user document has the following elds:
eld string user The name of the new user.
eld string pwd The users password. The pwd eld is not required if you run db.addUser()
(page 148) on the $external database to create users who have credentials stored externally
to MongoDB.
any document customData Any arbitrary information. This eld can be used to store any data an
admin wishes to associate with this particular user. For example, this could be the users full
name or employee id.
eld array roles The roles granted to the user. Can specify an empty array [] to create users without
roles.
eld document writeConcern The level of write concern for the creation operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Users created on the $external database should have credentials stored externally to MongoDB, as, for
example, with MongoDB Enterprise installations that use Kerberos.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.addUser() (page 148) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Considerations The db.addUser() (page 148) method returns a duplicate user error if the user exists.
When interacting with 2.6 and later MongoDB instances, db.addUser() (page 148) sends unencrypted passwords.
To encrypt the password in transit use SSL.
In the 2.6 version of the shell, db.addUser() (page 148) is backwards compatible with both the 2.4 version of
db.addUser()
13
and the 2.2 version of db.addUser()
14
. In 2.6, for backwards compatibility db.addUser() (page 148)
creates users that approximate the privileges available in previous versions of MongoDB.
13
http://docs.mongodb.org/v2.4/reference/method/db.addUser
14
http://docs.mongodb.org/v2.2/reference/method/db.addUser
2.1. mongo Shell Methods 149
MongoDB Reference Manual, Release 2.6.4
Example The following db.addUser() (page 148) method creates a user Carlos on the database where the
command runs. The command gives Carlos the clusterAdmin and readAnyDatabase roles on the admin
database and the readWrite role on the current database:
{ user: "Carlos",
pwd: "cleartext password",
customData: { employeeId: 12345 },
roles: [
{ role: "clusterAdmin", db: "admin" },
{ role: "readAnyDatabase", db: "admin" },
"readWrite"
],
writeConcern: { w: "majority" , wtimeout: 5000 }
}
db.changeUserPassword()
Denition
db.changeUserPassword(username, password)
Updates a users password.
param string username Species an existing username with access privileges for this database.
param string password Species the corresponding password.
param string mechanism Species the authentication mechanism used. Defaults to
MONGODB-CR. PLAIN is used for SASL/LDAP authentication, available only in
MongoDB Enterprise.
Example The following operation changes the reporting users password to SOh3TbYhx8ypJPxmt1oOfL:
db.changeUserPassword("reporting", "SOh3TbYhx8ypJPxmt1oOfL")
db.createUser()
Denition
db.createUser(user, writeConcern)
Creates a newuser for the database where the method runs. db.createUser() (page 150) returns a duplicate
user error if the user already exists on the database.
The db.createUser() (page 150) method has the following syntax:
eld document user The document with authentication and access information about the user to
create.
eld document writeConcern The level of write concern for the creation operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The user document denes the user and has the following form:
{ user: "<name>",
pwd: "<cleartext password>",
customData: { <any information> },
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
150 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
]
}
The user document has the following elds:
eld string user The name of the new user.
eld string pwd The users password. The pwd eld is not required if you run
db.createUser() (page 150) on the $external database to create users who have cre-
dentials stored externally to MongoDB.
any document customData Any arbitrary information. This eld can be used to store any data an
admin wishes to associate with this particular user. For example, this could be the users full
name or employee id.
eld array roles The roles granted to the user. Can specify an empty array [] to create users without
roles.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.createUser() (page 150) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.createUser() (page 150) method wraps the createUser (page 263) command.
Behavior
Encryption db.createUser() (page 150) sends password to the MongoDB instance without encryption. To
encrypt the password during transmission, use SSL.
External Credentials Users created on the $external database should have credentials stored externally to Mon-
goDB, as, for example, with MongoDB Enterprise installations that use Kerberos.
Required Access You must have the createUser action on a database to create a new user on that database.
You must have the grantRole action on a roles database to grant the role to another user.
If you have the userAdmin or userAdminAnyDatabase role, you have those actions.
Examples The following db.createUser() (page 150) operation creates the accountAdmin01 user on the
products database.
use products
db.createUser( { "user" : "accountAdmin01",
"pwd": "cleartext password",
"customData" : { employeeId: 12345 },
"roles" : [ { role: "clusterAdmin", db: "admin" },
{ role: "readAnyDatabase", db: "admin" },
"readWrite"
2.1. mongo Shell Methods 151
MongoDB Reference Manual, Release 2.6.4
] },
{ w: "majority" , wtimeout: 5000 } )
The operation gives accountAdmin01 the following roles:
the clusterAdmin and readAnyDatabase roles on the admin database
the readWrite role on the products database
Create User with Roles The following operation creates accountUser in the products database and gives the
user the readWrite and dbAdmin roles.
use products
db.createUser(
{
user: "accountUser",
pwd: "password",
roles: [ "readWrite", "dbAdmin" ]
}
)
Create User Without Roles The following operation creates a user named reportsUser in the admin database
but does not yet assign roles:
use admin
db.createUser(
{
user: "reportsUser",
pwd: "password",
roles: [ ]
}
)
Create Administrative User with Roles The following operation creates a user named appAdmin in the admin
database and gives the user readWrite access to the config database, which lets the user change certain settings
for sharded clusters, such as to the balancer setting.
use admin
db.createUser(
{
user: "appAdmin",
pwd: "password",
roles:
[
{ role: "readWrite", db: "config" },
"clusterAdmin"
]
}
)
db.dropAllUsers()
Denition
152 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.dropAllUsers(writeConcern)
Removes all users from the current database.
Warning: The dropAllUsers method removes all users from the database.
The dropAllUsers method takes the following arguments:
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The db.dropAllUsers() (page 152) method wraps the dropAllUsersFromDatabase (page 264)
command.
Required Access You must have the dropUser action on a database to drop a user from that database.
Example The following db.dropAllUsers() (page 152) operation drops every user from the products
database.
use products
db.dropAllUsers( {w: "majority", wtimeout: 5000} )
The n eld in the results document shows the number of users removed:
{ "n" : 12, "ok" : 1 }
db.dropUser()
Denition
db.dropUser(username, writeConcern)
Removes the user from the current database.
The db.dropUser() (page 153) method takes the following arguments:
param string username The name of the user to remove from the database.
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The db.dropUser() (page 153) method wraps the dropUser (page 265) command.
Required Access You must have the dropUser action on a database to drop a user from that database.
Example The following db.dropUser() (page 153) operation drops the accountAdmin01 user on the
products database.
use products
db.dropUser("accountAdmin01", {w: "majority", wtimeout: 5000})
2.1. mongo Shell Methods 153
MongoDB Reference Manual, Release 2.6.4
db.getUser()
Denition
db.getUser(username)
Returns user information for a specied user. Run this method on the users database. The user must exist on
the database on which the method runs.
The db.getUser() (page 154) method has the following parameter:
param string username The name of the user for which to retrieve information.
db.getUser() (page 154) wraps the usersInfo (page 270) command.
Required Access You must have the viewUser action on another users database to view the other users creden-
tials.
You can view your own information.
Example The following sequence of operations returns information about the appClient user on the accounts
database:
use accounts
db.getUser("appClient")
db.getUsers()
Denition
db.getUsers()
Returns information for all the users in the database.
db.getUsers() (page 154) wraps the usersInfo (page 270) command.
Required Access You must have the viewUser action on another users database to view the other users creden-
tials.
You can view your own information.
db.grantRolesToUser()
Denition
db.grantRolesToUser(username, roles, writeConcern)
Grants additional roles to a user.
The grantRolesToUser method uses the following syntax:
db.grantRolesToUser( "<username>", [ <roles> ], { <writeConcern> } )
The grantRolesToUser method takes the following arguments:
param string user The name of the user to whom to grant roles.
eld array roles An array of additional roles to grant to the user.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
154 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.grantRolesToUser() (page 154) runs, you
can either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.grantRolesToUser() (page 154) method wraps the grantRolesToUser (page 266) com-
mand.
Required Access You must have the grantRole action on a database to grant a role on that database.
Example Given a user accountUser01 in the products database with the following roles:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]
The following grantRolesToUser() operation gives accountUser01 the readWrite role on the
products database and the read role on the stock database.
use products
db.grantRolesToUser(
"accountUser01",
[ "readWrite" , { role: "read", db: "stock" } ],
{ w: "majority" , wtimeout: 4000 }
)
The user accountUser01 in the products database now has the following roles:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]
db.removeUser()
Deprecated since version 2.6: Use db.dropUser() (page 153) instead of db.removeUser() (page 155)
Denition
2.1. mongo Shell Methods 155
MongoDB Reference Manual, Release 2.6.4
db.removeUser(username)
Removes the specied username from the database.
The db.removeUser() (page 155) method has the following parameter:
param string username The database username.
db.revokeRolesFromUser()
Denition
db.revokeRolesFromUser()
Removes a one or more roles from a user on the current database. The db.revokeRolesFromUser()
(page 156) method uses the following syntax:
db.revokeRolesFromUser( "<username>", [ <roles> ], { <writeConcern> } )
The revokeRolesFromUser method takes the following arguments:
param string user The name of the user from whom to revoke roles.
eld array roles The roles to remove from the user.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.revokeRolesFromUser() (page 156) runs,
you can either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.revokeRolesFromUser() (page 156) method wraps the revokeRolesFromUser (page 267)
command.
Required Access You must have the revokeRole action on a database to revoke a role on that database.
Example The accountUser01 user in the products database has the following roles:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]
156 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The following db.revokeRolesFromUser() (page 156) method removes the two of the users roles: the read
role on the stock database and the readWrite role on the products database, which is also the database on
which the method runs:
use products
db.revokeRolesFromUser( "accountUser01",
[ { role: "read", db: "stock" }, "readWrite" ],
{ w: "majority" }
)
The user accountUser01 user in the products database now has only one remaining role:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]
db.updateUser()
Denition
db.updateUser(username, update, writeConcern)
Updates the users prole on the database on which you run the method. An update to a eld completely
replaces the previous elds values. This includes updates to the users roles array.
Warning: When you update the roles array, you completely replace the previous arrays values. To
add or remove roles without replacing all the users existing roles, use the db.grantRolesToUser()
(page 154) or db.revokeRolesFromUser() (page 156) methods.
The db.updateUser() (page 157) method uses the following syntax:
db.updateUser(
"<username>",
{
customData : { <any information> },
roles : [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
pwd: "<cleartext password>"
},
writeConcern: { <write concern> }
)
The db.updateUser() (page 157) method has the following arguments.
param string username The name of the user to update.
param document update A document containing the replacement data for the user. This data com-
pletely replaces the corresponding data for the user.
eld document writeConcern The level of write concern for the update operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The update document species the elds to update and their new values. All elds in the update document
are optional, but must include at least one eld.
2.1. mongo Shell Methods 157
MongoDB Reference Manual, Release 2.6.4
The update document has the following elds:
eld document customData Any arbitrary information.
eld array roles The roles granted to the user. An update to the roles array overrides the previous
arrays values.
eld string pwd The users password.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.updateUser() (page 157) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.updateUser() (page 157) method wraps the updateUser (page 268) command.
Behavior db.updateUser() (page 157) sends password to the MongoDB instance without encryption. To en-
crypt the password during transmission, use SSL.
Required Access You must have access that includes the revokeRole action on all databases in order to update a
users roles array.
You must have the grantRole action on a roles database to add a role to a user.
To change another users pwd or customData eld, you must have the changeAnyPassword and
changeAnyCustomData actions respectively on that users database.
To modify your own password or custom data, you must have the changeOwnPassword and
changeOwnCustomData actions respectively on the cluster resource.
Example Given a user appClient01 in the products database with the following user info:
{
"_id" : "products.appClient01",
"user" : "appClient01",
"db" : "products",
"customData" : { "empID" : "12345", "badge" : "9156" },
"roles" : [
{ "role" : "readWrite",
"db" : "products"
},
{ "role" : "read",
"db" : "inventory"
}
]
}
The following db.updateUser() (page 157) method completely replaces the users customData and roles
data:
158 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
use products
db.updateUser( "appClient01",
{
customData : { employeeId : "0x3039" },
roles : [
{ role : "read", db : "assets" }
]
}
)
The user appClient01 in the products database now has the following user information:
{
"_id" : "products.appClient01",
"user" : "appClient01",
"db" : "products",
"customData" : { "employeeId" : "0x3039" },
"roles" : [
{ "role" : "read",
"db" : "assets"
}
]
}
2.1.7 Role Management
Role Management Methods
Name Description
db.createRole() (page 159) Creates a role and species its privileges.
db.dropAllRoles() (page 161) Deletes all user-dened roles associated with a database.
db.dropRole() (page 161) Deletes a user-dened role.
db.getRole() (page 162) Returns information for the specied role.
db.getRoles() (page 162) Returns information for all the user-dened roles in a
database.
db.grantPrivilegesToRole() (page 163) Assigns privileges to a user-dened role.
db.grantRolesToRole() (page 164) Species roles from which a user-dened role inherits
privileges.
db.revokePrivilegesFromRole()
(page 165)
Removes the specied privileges from a user-dened role.
db.revokeRolesFromRole() (page 167) Removes a role from a user.
db.updateRole() (page 169) Updates a user-dened role.
db.createRole()
Denition
db.createRole(role, writeConcern)
Creates a role and species its privileges. The role applies to the database on which you run the method. The
db.createRole() (page 159) method returns a duplicate role error if the role already exists in the database.
The db.createRole() (page 159) method takes the following arguments:
param document role A document containing the name of the role and the role denition.
2.1. mongo Shell Methods 159
MongoDB Reference Manual, Release 2.6.4
eld document writeConcern The level of write concern to apply to this operation. The
writeConcern document uses the same elds as the getLastError (page 243) command.
The role document has the following form:
{ role: "<name>",
privileges: [
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
]
}
The role document has the following elds:
eld string role The name of the new role.
eld array privileges The privileges to grant the role. A privilege consists of a resource and per-
mitted actions. You must specify the privileges eld. Use an empty array to specify no
privileges. For the syntax of a privilege, see the privileges array.
eld array roles An array of roles from which this role inherits privileges. You must specify the
roles eld. Use an empty array to specify no roles.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.createRole() (page 159) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.createRole() (page 159) method wraps the createRole (page 272) command.
Behavior A roles privileges apply to the database where the role is created. The role can inherit privileges from
other roles in its database. A role created on the admin database can include privileges that apply to all databases or
to the cluster and can inherit privileges from roles in other databases.
Required Access You must have the createRole action on a database to create a role on that database.
You must have the grantRole action on the database that a privilege targets in order to grant that privilege to a role.
If the privilege targets multiple databases or the cluster resource , you must have the grantRole action on the
admin database.
You must have the grantRole action on a roles database to grant the role to another role.
Example The following db.createRole() (page 159) method creates the myClusterwideAdmin role on
the admin database:
160 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
use admin
db.createRole({ role: "myClusterwideAdmin",
privileges: [
{ resource: { cluster: true }, actions: [ "addShard" ] },
{ resource: { db: "config", collection: "" }, actions: [ "find", "update", "insert", "remove" ] },
{ resource: { db: "users", collection: "usersCollection" }, actions: [ "update", "insert", "remove" ] },
{ resource: { db: "", collection: "" }, actions: [ "find" ] }
],
roles: [
{ role: "read", db: "admin" }
],
writeConcern: { w: "majority" , wtimeout: 5000 }
})
db.dropAllRoles()
Denition
db.dropAllRoles(writeConcern)
Deletes all user-dened roles on the database where you run the method.
Warning: The dropAllRoles method removes all user-dened roles from the database.
The dropAllRoles method takes the following argument:
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Returns The number of user-dened roles dropped.
The db.dropAllRoles() (page 161) method wraps the dropAllRolesFromDatabase (page 273)
command.
Required Access You must have the dropRole action on a database to drop a role from that database.
Example The following operations drop all user-dened roles from the products database and uses a write con-
cern of majority.
use products
db.dropAllRoles( { w: "majority" } )
The method returns the number of roles dropped:
4
db.dropRole()
Denition
db.dropRole(rolename, writeConcern)
Deletes a user-dened role from the database on which you run the method.
The db.dropRole() (page 161) method takes the following arguments:
2.1. mongo Shell Methods 161
MongoDB Reference Manual, Release 2.6.4
param string rolename The name of the user-dened role to remove from the database.
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The db.dropRole() (page 161) method wraps the dropRole (page 274) command.
Required Access You must have the dropRole action on a database to drop a role from that database.
Example The following operations remove the readPrices role from the products database:
use products
db.dropRole( "readPrices", { w: "majority" } )
db.getRole()
Denition
db.getRole(rolename, showPrivileges)
Returns the roles from which this role inherits privileges. Optionally, the method can also return all the roles
privileges.
Run db.getRole() (page 162) from the database that contains the role. The command can retrieve informa-
tion for both user-dened roles and built-in roles.
The db.getRole() (page 162) method takes the following arguments:
param string rolename The name of the role.
param document showPrivileges If true, returns the roles privileges. Pass this argument as a
document: {showPrivileges: true}.
db.getRole() (page 162) wraps the rolesInfo (page 281) command.
Required Access To view a roles information, you must be explicitly granted the role or must have the viewRole
action on the roles database.
Examples The following operation returns role inheritance information for the role associate dened on the
products database:
use products
db.getRole( "associate" )
The following operation returns role inheritance information and privileges for the role associate dened on the
products database:
use products
db.getRole( "associate", { showPrivileges: true } )
db.getRoles()
Denition
162 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.getRoles()
Returns information for all the roles in the database on which the command runs. The method can be run with
or without an argument.
If run without an argument, db.getRoles() (page 162) returns inheritance information for the databases
user-dened roles.
To return more information, pass the db.getRoles() (page 162) a document with the following elds:
eld integer rolesInfo Set this eld to 1 to retrieve all user-dened roles.
eld Boolean showBuiltinRoles Set to true to display built-in roles as well as user-dened roles.
eld Boolean showPrivileges Set the eld to true to show role privileges, including both privi-
leges inherited from other roles and privileges dened directly. By default, the command returns
only the roles from which this role inherits privileges and does not return specic privileges.
db.getRoles() (page 162) wraps the rolesInfo (page 281) command.
Required Access To view a roles information, you must be explicitly granted the role or must have the viewRole
action on the roles database.
Example The following operations return documents for all the roles on the products database, including role
privileges and built-in roles:
db.getRoles(
{
rolesInfo: 1,
showPrivileges:true,
showBuiltinRoles: true
}
)
db.grantPrivilegesToRole()
Denition
db.grantPrivilegesToRole(rolename, privileges, writeConcern)
Grants additional privileges to a user-dened role.
The grantPrivilegesToRole() method uses the following syntax:
db.grantPrivilegesToRole(
"< rolename >",
[
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
{ < writeConcern > }
)
The grantPrivilegesToRole() method takes the following arguments:
param string rolename The name of the role to grant privileges to.
eld array privileges The privileges to add to the role. For the format of a privilege, see
privileges.
2.1. mongo Shell Methods 163
MongoDB Reference Manual, Release 2.6.4
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The grantPrivilegesToRole() method can grant one or more privileges. Each <privilege> has the
following syntax:
{ resource: { <resource> }, actions: [ "<action>", ... ] }
The db.grantPrivilegesToRole() (page 163) method wraps the grantPrivilegesToRole
(page 275) command.
Behavior A roles privileges apply to the database where the role is created. A role created on the admin database
can include privileges that apply to all databases or to the cluster.
Required Access You must have the grantRole action on the database a privilege targets in order to grant the
privilege. To grant a privilege on multiple databases or on the cluster resource, you must have the grantRole
action on the admin database.
Example The following db.grantPrivilegesToRole() (page 163) operation grants two additional privi-
leges to the role inventoryCntrl01, which exists on the products database. The operation is run on that
database:
use products
db.grantPrivilegesToRole(
"inventoryCntrl01",
[
{
resource: { db: "products", collection: "" },
actions: [ "insert" ]
},
{
resource: { db: "products", collection: "system.indexes" },
actions: [ "find" ]
}
],
{ w: "majority" }
)
The rst privilege permits users with this role to perform the insert action on all collections of the products
database, except the system collections (page 654). To access a system collection, a privilege must explicitly specify
the system collection in the resource document, as in the second privilege.
The second privilege permits users with this role to perform the find action on the product databases system
collection named system.indexes (page 655).
db.grantRolesToRole()
Denition
db.grantRolesToRole(rolename, roles, writeConcern)
Grants roles to a user-dened role.
The grantRolesToRole method uses the following syntax:
164 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.grantRolesToRole( "<rolename>", [ <roles> ], { <writeConcern> } )
The grantRolesToRole method takes the following arguments:
param string rolename The name of the role to which to grant sub roles.
eld array roles An array of roles from which to inherit.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.grantRolesToRole() (page 164) runs, you
can either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.grantRolesToRole() (page 164) method wraps the grantRolesToRole (page 276) com-
mand.
Behavior A role can inherit privileges from other roles in its database. A role created on the admin database can
inherit privileges from roles in any database.
Required Access You must have the grantRole action on a database to grant a role on that database.
Example The following grantRolesToRole() operation updates the productsReaderWriter role in the
products database to inherit the privileges of productsReader role:
use products
db.grantRolesToRole(
"productsReaderWriter",
[ "productsReader" ],
{ w: "majority" , wtimeout: 5000 }
)
db.revokePrivilegesFromRole()
Denition
db.revokePrivilegesFromRole(rolename, privileges, writeConcern)
Removes the specied privileges from the user-dened role on the database where the method runs. The
revokePrivilegesFromRole method has the following syntax:
db.revokePrivilegesFromRole(
"<rolename>",
[
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
2.1. mongo Shell Methods 165
MongoDB Reference Manual, Release 2.6.4
{ <writeConcern> }
)
The revokePrivilegesFromRole method takes the following arguments:
param string rolename The name of the user-dened role from which to revoke privileges.
eld array privileges An array of privileges to remove from the role. See privileges for more
information on the format of the privileges.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The db.revokePrivilegesFromRole() (page 165) method wraps the
revokePrivilegesFromRole (page 277) command.
Behavior To revoke a privilege, the resource document pattern must match exactly the resource eld of
that privilege. The actions eld can be a subset or match exactly.
For example, given the role accountRole in the products database with the following privilege that species the
products database as the resource:
{
"resource" : {
"db" : "products",
"collection" : ""
},
"actions" : [
"find",
"update"
]
}
You cannot revoke find and/or update from just one collection in the products database. The following opera-
tions result in no change to the role:
use products
db.revokePrivilegesFromRole(
"accountRole",
[
{
resource : {
db : "products",
collection : "gadgets"
},
actions : [
"find",
"update"
]
}
]
)
db.revokePrivilegesFromRole(
"accountRole",
[
{
resource : {
166 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db : "products",
collection : "gadgets"
},
actions : [
"find"
]
}
]
)
To revoke the "find" and/or the "update" action from the role accountRole, you must match the resource
document exactly. For example, the following operation revokes just the "find" action from the existing privilege.
use products
db.revokePrivilegesFromRole(
"accountRole",
[
{
resource : {
db : "products",
collection : ""
},
actions : [
"find"
]
}
]
)
Required Access You must have the revokeRole action on the database a privilege targets in order to revoke
that privilege. If the privilege targets multiple databases or the cluster resource, you must have the revokeRole
action on the admin database.
Example The following operation removes multiple privileges from the associates role:
db.revokePrivilegesFromRole(
"associate",
[
{
resource: { db: "products", collection: "" },
actions: [ "createCollection", "createIndex", "find" ]
},
{
resource: { db: "products", collection: "orders" },
actions: [ "insert" ]
}
],
{ w: "majority" }
)
db.revokeRolesFromRole()
Denition
db.revokeRolesFromRole(rolename, roles, writeConcern)
Removes the specied inherited roles from a role.
2.1. mongo Shell Methods 167
MongoDB Reference Manual, Release 2.6.4
The revokeRolesFromRole method uses the following syntax:
db.revokeRolesFromRole( "<rolename>", [ <roles> ], { <writeConcern> } )
The revokeRolesFromRole method takes the following arguments:
param string rolename The name of the role from which to revoke roles.
eld array roles The inherited roles to remove.
eld document writeConcern The level of write concern to apply to this operation. The
writeConcern document uses the same elds as the getLastError (page 243) command.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.revokeRolesFromRole() (page 167) runs,
you can either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.revokeRolesFromRole() (page 167) method wraps the revokeRolesFromRole (page 280)
command.
Required Access You must have the revokeRole action on a database to revoke a role on that database.
Example The purchaseAgents role in the emea database inherits privileges from several other roles, as listed
in the roles array:
{
"_id" : "emea.purchaseAgents",
"role" : "purchaseAgents",
"db" : "emea",
"privileges" : [],
"roles" : [
{
"role" : "readOrdersCollection",
"db" : "emea"
},
{
"role" : "readAccountsCollection",
"db" : "emea"
},
{
"role" : "writeOrdersCollection",
"db" : "emea"
}
]
}
The following db.revokeRolesFromRole() (page 167) operation on the emea database removes two roles
from the purchaseAgents role:
168 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
use emea
db.revokeRolesFromRole( "purchaseAgents",
[
"writeOrdersCollection",
"readOrdersCollection"
],
{ w: "majority" , wtimeout: 5000 }
)
The purchaseAgents role now contains just one role:
{
"_id" : "emea.purchaseAgents",
"role" : "purchaseAgents",
"db" : "emea",
"privileges" : [],
"roles" : [
{
"role" : "readAccountsCollection",
"db" : "emea"
}
]
}
db.updateRole()
Denition
db.updateRole(rolename, update, writeConcern)
Updates a user-dened role. The db.updateRole() (page 169) method must run on the roles database.
An update to a eld completely replaces the previous elds values. To grant or remove roles or privileges
without replacing all values, use one or more of the following methods:
db.grantRolesToRole() (page 164)
db.grantPrivilegesToRole() (page 163)
db.revokeRolesFromRole() (page 167)
db.revokePrivilegesFromRole() (page 165)
Warning: An update to the privileges or roles array completely replaces the previous arrays values.
The updateRole() method uses the following syntax:
db.updateRole(
"<rolename>",
{
privileges:
[
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
roles:
[
{ role: "<role>", db: "<database>" } | "<role>",
...
]
2.1. mongo Shell Methods 169
MongoDB Reference Manual, Release 2.6.4
},
{ <writeConcern> }
)
The db.updateRole() (page 169) method takes the following arguments.
param string rolename The name of the user-dened role to update.
param document update A document containing the replacement data for the role. This data com-
pletely replaces the corresponding data for the role.
eld document writeConcern The level of write concern for the update operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
The update document species the elds to update and the new values. Each eld in the update document
is optional, but the document must include at least one eld. The update document has the following elds:
eld array privileges Required if you do not specify roles array. The privileges to grant the role.
An update to the privileges array overrides the previous arrays values. For the syntax for
specifying a privilege, see the privileges array.
eld array roles Required if you do not specify privileges array. The roles from which this
role inherits privileges. An update to the roles array overrides the previous arrays values.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where db.updateRole() (page 169) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
The db.updateRole() (page 169) method wraps the updateRole (page 284) command.
Behavior A roles privileges apply to the database where the role is created. The role can inherit privileges from
other roles in its database. A role created on the admin database can include privileges that apply to all databases or
to the cluster and can inherit privileges from roles in other databases.
Required Access You must have the revokeRole action on all databases in order to update a role.
You must have the grantRole action on the database of each role in the roles array to update the array.
You must have the grantRole action on the database of each privilege in the privileges array to update the
array. If a privileges resource spans databases, you must have grantRole on the admin database. A privilege
spans databases if the privilege is any of the following:
a collection in all databases
all collections and all database
the cluster resource
170 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example The following db.updateRole() (page 169) method replaces the privileges and the roles for
the inventoryControl role that exists in the products database. The method runs on the database that contains
inventoryControl:
use products
db.updateRole(
"inventoryControl",
{
privileges:
[
{
resource: { db:"products", collection:"clothing" },
actions: [ "update", "createCollection", "createIndex"]
}
],
roles:
[
{
role: "read",
db: "products"
}
]
},
{ w:"majority" }
)
To view a roles privileges, use the rolesInfo (page 281) command.
2.1.8 Replication
Replication Methods
Name Description
rs.add() (page 172) Adds a member to a replica set.
rs.addArb() (page 173) Adds an arbiter to a replica set.
rs.conf() (page 173) Returns the replica set conguration document.
rs.freeze() (page 173) Prevents the current member from seeking election as primary for a period of time.
rs.help() (page 173) Returns basic help text for replica set functions.
rs.initiate()
(page 173)
Initializes a new replica set.
rs.printReplicationInfo()
(page 174)
Prints a report of the status of the replica set from the perspective of the primary.
rs.printSlaveReplicationInfo()
(page 174)
Prints a report of the status of the replica set from the perspective of the
secondaries.
rs.reconfig()
(page 175)
Re-congures a replica set by applying a new replica set conguration object.
rs.remove() (page 177) Remove a member from a replica set.
rs.slaveOk()
(page 177)
Sets the slaveOk property for the current connection. Deprecated. Use
readPref() (page 94) and Mongo.setReadPref() (page 202) to set read
preference.
rs.status() (page 177) Returns a document with information about the state of the replica set.
rs.stepDown()
(page 177)
Causes the current primary to become a secondary which forces an election.
rs.syncFrom()
(page 178)
Sets the member that this replica set member will sync from, overriding the default
sync target selection logic.
2.1. mongo Shell Methods 171
MongoDB Reference Manual, Release 2.6.4
rs.add()
Denition
rs.add()
Adds a member to a replica set. To run the method, you must connect to the primary of the replica set.
param string,document host The new member to add to the replica set.
If a string, specify the hostname and optionally the port number for the new member. See Pass
a Hostname String to rs.add() (page 172) for an example.
If a document, specify a replica set member conguration document as found in the members
array. You must specify _id and the host elds in the member conguration document. See
Pass a Member Conguration Document to rs.add() (page 172) for an example.
See http://docs.mongodb.org/manualreference/replica-configuration
document for full documentation of all replica set conguration options
param boolean arbiterOnly Applies only if the <host> value is a string. If true, the added host
is an arbiter.
rs.add() (page 172) provides a wrapper around some of the functionality of the replSetReconfig
(page 294) database command and the corresponding mongo (page 580) shell helper rs.reconfig()
(page 175). See the http://docs.mongodb.org/manualreference/replica-configuration
document for full documentation of all replica set conguration options.
Behavior rs.add() (page 172) can, in some cases, force an election for primary which will disconnect the shell.
In such cases, the mongo (page 580) shell displays an error even if the operation succeeds.
Example
Pass a Hostname String to rs.add() The following operation adds a mongod (page 555) instance, running on
the host mongodb3.example.net and accessible on the default port 27017:
rs.add('mongodb3.example.net:27017')
If mongodb3.example.net is an arbiter, use the following form:
rs.add('mongodb3.example.net:27017', true)
Pass a Member Conguration Document to rs.add() The following operation adds a mongod (page 555)
instance, running on the host mongodb4.example.net and accessible on the default port 27017, as a priority
0 secondary member:
rs.add( { _id: 4, host: "mongodbd4.example.net:27017", priority: 0 } )
You must specify _id and the host elds in the member conguration document.
The _id value must be unique. Use rs.conf() (page 173) to see the existing _id values in the replica set cong-
uration document, and set _id to the next unused _id value in the replica set.
See the http://docs.mongodb.org/manualreference/replica-configuration for the available
replica set member conguration settings.
See http://docs.mongodb.org/manualadministration/replica-sets for more examples and in-
formation.
172 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
rs.addArb()
Description
rs.addArb(host)
Adds a new arbiter to an existing replica set.
The rs.addArb() (page 173) method takes the following parameter:
param string host Species the hostname and optionally the port number of the arbiter member to
add to replica set.
This function briey disconnects the shell and forces a reconnection as the replica set renegotiates which member
will be primary. As a result, the shell displays an error even if this command succeeds.
rs.conf()
rs.conf()
Returns a document that contains the current replica set conguration document.
See http://docs.mongodb.org/manualreference/replica-configuration for more infor-
mation on the replica set conguration document.
rs.config()
rs.config() (page 173) is an alias of rs.conf() (page 173).
rs.freeze()
Description
rs.freeze(seconds)
Makes the current replica set member ineligible to become primary for the period specied.
The rs.freeze() (page 173) method has the following parameter:
param number seconds The duration the member is ineligible to become primary.
rs.freeze() (page 173) provides a wrapper around the database command replSetFreeze (page 289).
rs.help()
rs.help()
Returns a basic help text for all of the replication related shell functions.
rs.initiate()
Description
rs.initiate(conguration)
Initiates a replica set. Optionally takes a conguration argument in the form of a document that holds the
conguration of a replica set.
The rs.initiate() (page 173) method has the following parameter:
param document conguration A document that species configuration settings for
the new replica set. If a conguration is not specied, MongoDB uses a default conguration.
2.1. mongo Shell Methods 173
MongoDB Reference Manual, Release 2.6.4
The rs.initiate() (page 173) method provides a wrapper around the replSetInitiate (page 292)
database command.
Replica Set Conguration See http://docs.mongodb.org/manualadministration/replica-set-member-configuration
and http://docs.mongodb.org/manualreference/replica-configuration for examples of
replica set conguration and invitation objects.
rs.printReplicationInfo()
rs.printReplicationInfo()
New in version 2.6.
Prints a formatted report of the status of a replica set from the perspective of the primary member of the set
if run on the primary.
15
The displayed report formats the data returned by db.getReplicationInfo()
(page 117).
Note: The rs.printReplicationInfo() (page 174) in the mongo (page 580) shell does
not return JSON. Use rs.printReplicationInfo() (page 174) for manual inspection, and
db.getReplicationInfo() (page 117) in scripts.
The output of rs.printReplicationInfo() (page 174) is identical to that of
db.printReplicationInfo() (page 121).
Output Example The following example is a sample output from the rs.printReplicationInfo()
(page 174) method run on the primary:
configured oplog size: 192MB
log length start to end: 65422secs (18.17hrs)
oplog first event time: Mon Jun 23 2014 17:47:18 GMT-0400 (EDT)
oplog last event time: Tue Jun 24 2014 11:57:40 GMT-0400 (EDT)
now: Thu Jun 26 2014 14:24:39 GMT-0400 (EDT)
Output Fields rs.printReplicationInfo() (page 174) formats and prints the data returned by
db.getReplicationInfo() (page 117):
congured oplog size Displays the db.getReplicationInfo.logSizeMB (page 118) value.
log length start to end Displays the db.getReplicationInfo.timeDiff (page 118) and
db.getReplicationInfo.timeDiffHours (page 118) values.
oplog rst event time Displays the db.getReplicationInfo.tFirst (page 118).
oplog last event time Displays the db.getReplicationInfo.tLast (page 118).
now Displays the db.getReplicationInfo.now (page 118).
See db.getReplicationInfo() (page 117) for description of the data.
rs.printSlaveReplicationInfo()
Denition
15
If run on a secondary, the method calls db.printSlaveReplicationInfo() (page 123). See
db.printSlaveReplicationInfo() (page 123) for details.
174 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
rs.printSlaveReplicationInfo()
Returns a formatted report of the status of a replica set from the perspective of the secondary member of the set.
The output is identical to that of db.printSlaveReplicationInfo() (page 123).
Output The following is example output from the rs.printSlaveReplicationInfo() (page 174) method
issued on a replica set with two secondary members:
source: m1.example.net:27017
syncedTo: Thu Apr 10 2014 10:27:47 GMT-0400 (EDT)
0 secs (0 hrs) behind the primary
source: m2.example.net:27017
syncedTo: Thu Apr 10 2014 10:27:47 GMT-0400 (EDT)
0 secs (0 hrs) behind the primary
A delayed member may show as 0 seconds behind the primary when the inactivity period on the primary is greater
than the slaveDelay value.
rs.recong()
Denition
rs.reconfig(conguration, force)
Recongures an existing replica set, overwriting the existing replica set conguration. To run the method, you
must connect to the primary of the replica set.
param document conguration A document that species the conguration of a replica set.
param document force If set as { force: true }, this forces the replica set to accept the
new conguration even if a majority of the members are not accessible. Use with caution, as
this can lead to rollback situations.
When used to recongure an existing replica set, rst retrieve the current conguration with rs.conf()
(page 173), modify the conguration document as needed, and then pass the modied document to
rs.reconfig() (page 175).
rs.reconfig() (page 175) provides a wrapper around the replSetReconfig (page 294) database com-
mand.
Behavior The method disconnects the mongo (page 580) shell and forces a reconnection as the replica set renego-
tiates which member will be primary. As a result, the shell will display an error even if this command succeeds.
The rs.reconfig() (page 175) shell method can force the current primary to step down and triggers an election
in some situations. When the primary steps down, the primary closes all client connections. This is by design. Since
this typically takes 10-20 seconds, attempt to make such changes during scheduled maintenance periods.
Warning: Using rs.reconfig() (page 175) with { force: true } can lead to rollback situations and
other difcult-to-recover-from situations. Exercise caution when using this option.
Examples A replica set named rs0 has the following conguration:
{
"_id" : "rs0",
"version" : 1,
"members" : [
{
2.1. mongo Shell Methods 175
MongoDB Reference Manual, Release 2.6.4
"_id" : 0,
"host" : "mongodb0.example.net:27017"
},
{
"_id" : 1,
"host" : "mongodb1.example.net:27017"
},
{
"_id" : 2,
"host" : "mongodb2.example.net:27017"
}
]
}
The following sequence of operations updates the priority of the second member. The operations are issued
through a mongo (page 580) shell connected to the primary.
cfg = rs.conf();
cfg.members[1].priority = 2;
rs.reconfig(cfg);
1. The rst statement uses the rs.conf() (page 173) method to retrieve a document containing the current
configuration for the replica set and sets the document to the local variable cfg.
2. The second statement sets a priority value to the second document in the members array. For additional
settings, see replica set conguration settings.
To access the member conguration document in the array, the statement uses the array index and not the replica
set members _id eld.
3. The last statement calls the rs.reconfig() (page 175) method with the modied cfg to initialize this new
conguration. Upon successful reconguration, the replica set conguration will resemble the following:
{
"_id" : "rs0",
"version" : 2,
"members" : [
{
"_id" : 0,
"host" : "mongodb0.example.net:27017"
},
{
"_id" : 1,
"host" : "mongodb1.example.net:27017",
"priority" : 2
},
{
"_id" : 2,
"host" : "mongodb2.example.net:27017"
}
]
}
See also:
http://docs.mongodb.org/manualreference/replica-configuration and
http://docs.mongodb.org/manualadministration/replica-sets.
176 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
rs.remove()
Denition
rs.remove(hostname)
Removes the member described by the hostname parameter from the current replica set. This function will
disconnect the shell briey and forces a reconnection as the replica set renegotiates which member will be
primary. As a result, the shell will display an error even if this command succeeds.
The rs.remove() (page 177) method has the following parameter:
param string hostname The hostname of a system in the replica set.
Note: Before running the rs.remove() (page 177) operation, you must shut down the replica set member
that youre removing.
Changed in version 2.2: This procedure is no longer required when using rs.remove() (page 177), but it
remains good practice.
rs.slaveOk()
rs.slaveOk()
Provides a shorthand for the following operation:
db.getMongo().setSlaveOk()
This allows the current connection to allow read operations to run on secondary members. See the
readPref() (page 94) method for more ne-grained control over read preference in the mongo
(page 580) shell.
rs.status()
rs.status()
Returns A document with status information.
This output reects the current status of the replica set, using data derived from the heartbeat packets sent by the
other members of the replica set.
This method provides a wrapper around the replSetGetStatus (page 289)database command. See the
documentation of the command for a complete description of the output (page 290).
rs.stepDown()
Description
rs.stepDown(seconds)
Forces the current replica set member to step down as primary and then attempt to avoid election as primary for
the designated number of seconds. Produces an error if the current member is not the primary.
The rs.stepDown() (page 177) method has the following parameter:
param number seconds The duration of time that the stepped-down member attempts to avoid re-
election as primary. If this parameter is not specied, the method uses the default value of 60
seconds.
2.1. mongo Shell Methods 177
MongoDB Reference Manual, Release 2.6.4
This function disconnects the shell briey and forces a reconnection as the replica set renegotiates which member
will be primary. As a result, the shell will display an error even if this command succeeds.
rs.stepDown() (page 177) provides a wrapper around the database command replSetStepDown
(page 294).
rs.syncFrom()
rs.syncFrom()
New in version 2.2.
Provides a wrapper around the replSetSyncFrom (page 295), which allows administrators to congure the
member of a replica set that the current member will pull data from. Specify the name of the member you want
to replicate from in the form of [hostname]:[port].
See replSetSyncFrom (page 295) for more details.
See http://docs.mongodb.org/manualtutorial/configure-replica-set-secondary-sync-target
for details how to use this command.
178 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
2.1. mongo Shell Methods 179
MongoDB Reference Manual, Release 2.6.4
2.1.9 Sharding
Sharding Methods
Name Description
sh._adminCommand
(page 181)
Runs a database command against the admin database, like db.runCommand()
(page 124), but can conrm that it is issued against a mongos (page 571).
sh._checkFullName()
(page 181)
Tests a namespace to determine if its well formed.
sh._checkMongos()
(page 181)
Tests to see if the mongo (page 580) shell is connected to a mongos (page 571)
instance.
sh._lastMigration()
(page 181)
Reports on the last chunk migration.
sh.addShard()
(page 182)
Adds a shard to a sharded cluster.
sh.addShardTag()
(page 183)
Associates a shard with a tag, to support tag aware sharding.
sh.addTagRange()
(page 183)
Associates range of shard keys with a shard tag, to support tag aware
sharding.
sh.disableBalancing()
(page 184)
Disable balancing on a single collection in a sharded database. Does not affect
balancing of other collections in a sharded cluster.
sh.enableBalancing()
(page 184)
Activates the sharded collection balancer process if previously disabled using
sh.disableBalancing() (page 184).
sh.enableSharding()
(page 185)
Enables sharding on a specic database.
sh.getBalancerHost()
(page 185)
Returns the name of a mongos (page 571) thats responsible for the balancer process.
sh.getBalancerState()
(page 185)
Returns a boolean to report if the balancer is currently enabled.
sh.help() (page 186) Returns help text for the sh methods.
sh.isBalancerRunning()
(page 186)
Returns a boolean to report if the balancer process is currently migrating chunks.
sh.moveChunk()
(page 186)
Migrates a chunk in a sharded cluster.
sh.removeShardTag()
(page 187)
Removes the association between a shard and a shard tag.
sh.setBalancerState()
(page 187)
Enables or disables the balancer which migrates chunks between shards.
sh.shardCollection()
(page 188)
Enables sharding for a collection.
sh.splitAt()
(page 188)
Divides an existing chunk into two chunks using a specic value of the shard key as
the dividing point.
sh.splitFind()
(page 189)
Divides an existing chunk that contains a document matching a query into two
approximately equal chunks.
sh.startBalancer()
(page 189)
Enables the balancer and waits for balancing to start.
sh.status()
(page 189)
Reports on the status of a sharded cluster, as db.printShardingStatus()
(page 122).
sh.stopBalancer()
(page 192)
Disables the balancer and waits for any in progress balancing rounds to complete.
sh.waitForBalancer()
(page 192)
Internal. Waits for the balancer state to change.
sh.waitForBalancerOff()
(page 192)
Internal. Waits until the balancer stops running.
sh.waitForDLock()
(page 193)
Internal. Waits for a specied distributed sharded cluster lock.
sh.waitForPingChange()
(page 193)
Internal. Waits for a change in ping state from one of the mongos (page 571) in the
sharded cluster.
180 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
sh._adminCommand()
Denition
sh._adminCommand(command, checkMongos)
Runs a database command against the admin database of a mongos (page 571) instance.
param string command A database command to run against the admin database.
param boolean checkMongos Require verication that the shell is connected to a mongos
(page 571) instance.
See also:
db.runCommand() (page 124)
sh._checkFullName()
Denition
sh._checkFullName(namespace)
Veries that a namespace name is well formed. If the namespace is well formed, the
sh._checkFullName() (page 181) method exits with no message.
Throws If the namespace is not well formed, sh._checkFullName() (page 181) throws: name
needs to be fully qualied <db>.<collection>
The sh._checkFullName() (page 181) method has the following parameter:
param string namespace The namespace of a collection. The namespace is the combination of the
database name and the collection name. Enclose the namespace in quotation marks.
sh._checkMongos()
sh._checkMongos()
Returns nothing
Throws not connected to a mongos
The sh._checkMongos() (page 181) method throws an error message if the mongo (page 580) shell is not
connected to a mongos (page 571) instance. Otherwise it exits (no return document or return code).
sh._lastMigration()
Denition
sh._lastMigration(namespace)
Returns information on the last migration performed on the specied database or collection.
The sh._lastMigration() (page 181) method has the following parameter:
param string namespace The namespace of a database or collection within the current database.
Output The sh._lastMigration() (page 181) method returns a document with details about the last migration
performed on the database or collection. The document contains the following output:
sh._lastMigration._id
The id of the migration task.
2.1. mongo Shell Methods 181
MongoDB Reference Manual, Release 2.6.4
sh._lastMigration.server
The name of the server.
sh._lastMigration.clientAddr
The IP address and port number of the server.
sh._lastMigration.time
The time of the last migration, formatted as ISODate.
sh._lastMigration.what
The specic type of migration.
sh._lastMigration.ns
The complete namespace of the collection affected by the migration.
sh._lastMigration.details
A document containing details about the migrated chunk. The document includes min and max sub-documents
with the bounds of the migrated chunk.
sh.addShard()
Denition
sh.addShard(host)
Adds a database instance or replica set to a sharded cluster. The optimal conguration is to deploy shards across
replica sets. This method must be run on a mongos (page 571) instance.
The sh.addShard() (page 182) method has the following parameter:
param string host The hostname of either a standalone database instance or of a replica set. Include
the port number if the instance is running on a non-standard port. Include the replica set name if
the instance is a replica set, as explained below.
The sh.addShard() (page 182) method has the following prototype form:
sh.addShard("<host>")
The host parameter can be in any of the following forms:
[hostname]
[hostname]:[port]
[replica-set-name]/[hostname]
[replica-set-name]/[hostname]:port
Warning: Do not use localhost for the hostname unless your conguration server is also running on
localhost.
New in version 2.6: mongos (page 571) installed from ofcial .deb and .rpm packages have the
bind_ip conguration set to 127.0.0.1 by default.
The sh.addShard() (page 182) method is a helper for the addShard (page 296) command. The addShard
(page 296) command has additional options which are not available with this helper.
Considerations
Balancing When you add a shard to a sharded cluster, you affect the balance of chunks among the shards of a cluster
for all existing sharded collections. The balancer will begin migrating chunks so that the cluster will achieve balance.
See http://docs.mongodb.org/manualcore/sharding-balancing for more information.
182 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Hidden Members
Important: You cannot include a hidden member in the seed list provided to sh.addShard() (page 182).
Example To add a shard on a replica set, specify the name of the replica set and the hostname of at least one member
of the replica set, as a seed. If you specify additional hostnames, all must be members of the same replica set.
The following example adds a replica set named repl0 and species one member of the replica set:
sh.addShard("repl0/mongodb3.example.net:27327")
sh.addShardTag()
Denition
sh.addShardTag(shard, tag)
New in version 2.2.
Associates a shard with a tag or identier. MongoDB uses these identiers to direct chunks that fall within a
tagged range to specic shards. sh.addTagRange() (page 183) associates chunk ranges with tag ranges.
param string shard The name of the shard to which to give a specic tag.
param string tag The name of the tag to add to the shard.
Only issue sh.addShardTag() (page 183) when connected to a mongos (page 571) instance.
Example The following example adds three tags, NYC, LAX, and NRT, to three shards:
sh.addShardTag("shard0000", "NYC")
sh.addShardTag("shard0001", "LAX")
sh.addShardTag("shard0002", "NRT")
See also:
sh.addTagRange() (page 183) and sh.removeShardTag() (page 187).
sh.addTagRange()
Denition
sh.addTagRange(namespace, minimum, maximum, tag)
New in version 2.2.
Attaches a range of shard key values to a shard tag created using the sh.addShardTag() (page 183) method.
sh.addTagRange() (page 183) takes the following arguments:
param string namespace The namespace of the sharded collection to tag.
param document minimum The minimum value of the shard key range to include in the
tag. The minimum is an inclusive match. Specify the minimum value in the form of
<fieldname>:<value>. This value must be of the same BSON type or types as the shard
key.
param document maximum The maximum value of the shard key range to include in the
tag. The maximum is an exclusive match. Specify the maximum value in the form of
<fieldname>:<value>. This value must be of the same BSON type or types as the shard
key.
2.1. mongo Shell Methods 183
MongoDB Reference Manual, Release 2.6.4
param string tag The name of the tag to attach the range specied by the minimum and maximum
arguments to.
Use sh.addShardTag() (page 183) to ensure that the balancer migrates documents that exist within the
specied range to a specic shard or set of shards.
Only issue sh.addTagRange() (page 183) when connected to a mongos (page 571) instance.
Behavior
Bounds Shard ranges are always inclusive of the lower value and exclusive of the upper boundary.
Dropped Collections If you add a tag range to a collection using sh.addTagRange() (page 183) and then later
drop the collection or its database, MongoDB does not remove the tag association. If you later create a new collection
with the same name, the old tag association will apply to the new collection.
Example Given a shard key of {state: 1, zip: 1}, the following operation creates a tag range covering
zip codes in New York State:
sh.addTagRange( "exampledb.collection",
{ state: "NY", zip: MinKey },
{ state: "NY", zip: MaxKey },
"NY"
)
sh.disableBalancing()
Description
sh.disableBalancing(namespace)
Disables the balancer for the specied sharded collection. This does not affect the balancing of chunks for other
sharded collections in the same cluster.
The sh.disableBalancing() (page 184) method has the following parameter:
param string namespace The namespace of the collection.
For more information on the balancing process, see http://docs.mongodb.org/manualtutorial/manage-sharded-cluster-balancer
and sharding-balancing.
sh.enableBalancing()
Description
sh.enableBalancing(namespace)
Enables the balancer for the specied namespace of the sharded collection.
The sh.enableBalancing() (page 184) method has the following parameter:
param string namespace The namespace of the collection.
Important: sh.enableBalancing() (page 184) does not start balancing. Rather, it allows balancing of
this collection the next time the balancer runs.
For more information on the balancing process, see http://docs.mongodb.org/manualtutorial/manage-sharded-cluster-balancer
and sharding-balancing.
184 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
sh.enableSharding()
Denition
sh.enableSharding(database)
Enables sharding on the specied database. This does not automatically shard any collections but makes it
possible to begin sharding collections using sh.shardCollection() (page 188).
The sh.enableSharding() (page 185) method has the following parameter:
param string database The name of the database shard. Enclose the name in quotation marks.
See also:
sh.shardCollection() (page 188)
sh.getBalancerHost()
sh.getBalancerHost()
Returns String in form hostname:port
sh.getBalancerHost() (page 185) returns the name of the server that is running the balancer.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerState() (page 185)
sh.isBalancerRunning() (page 186)
sh.setBalancerState() (page 187)
sh.startBalancer() (page 189)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
sh.getBalancerState()
sh.getBalancerState()
Returns boolean
sh.getBalancerState() (page 185) returns true when the balancer is enabled and false if the balancer
is disabled. This does not reect the current state of balancing operations: use sh.isBalancerRunning()
(page 186) to check the balancers current state.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerHost() (page 185)
sh.isBalancerRunning() (page 186)
sh.setBalancerState() (page 187)
2.1. mongo Shell Methods 185
MongoDB Reference Manual, Release 2.6.4
sh.startBalancer() (page 189)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
sh.help()
sh.help()
Returns a basic help text for all sharding related shell functions.
sh.isBalancerRunning()
sh.isBalancerRunning()
Returns boolean
Returns true if the balancer process is currently running and migrating chunks and false if the balancer process is
not running. Use sh.getBalancerState() (page 185) to determine if the balancer is enabled or disabled.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerHost() (page 185)
sh.getBalancerState() (page 185)
sh.setBalancerState() (page 187)
sh.startBalancer() (page 189)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
sh.moveChunk()
Denition
sh.moveChunk(namespace, query, destination)
Moves the chunk that contains the document specied by the query to the destination shard.
sh.moveChunk() (page 186) provides a wrapper around the moveChunk (page 303) database command
and takes the following arguments:
param string namespace The namespace of the sharded collection that contains the chunk to mi-
grate.
param document query An equality match on the shard key that selects the chunk to move.
param string destination The name of the shard to move.
Important: In most circumstances, allow the balancer to automatically migrate chunks, and avoid calling
sh.moveChunk() (page 186) directly.
186 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
See also:
moveChunk (page 303), sh.splitAt() (page 188), sh.splitFind() (page 189),
http://docs.mongodb.org/manualsharding, and chunk migration.
Example Given the people collection in the records database, the following operation nds the chunk that
contains the documents with the zipcode eld set to 53187 and then moves that chunk to the shard named
shard0019:
sh.moveChunk("records.people", { zipcode: "53187" }, "shard0019")
sh.removeShardTag()
Denition
sh.removeShardTag(shard, tag)
New in version 2.2.
Removes the association between a tag and a shard. Only issue sh.removeShardTag() (page 187) when
connected to a mongos (page 571) instance.
param string shard The name of the shard from which to remove a tag.
param string tag The name of the tag to remove from the shard.
See also:
sh.addShardTag() (page 183), sh.addTagRange() (page 183)
sh.setBalancerState()
Description
sh.setBalancerState(state)
Enables or disables the balancer. Use sh.getBalancerState() (page 185) to determine if the balancer is
currently enabled or disabled and sh.isBalancerRunning() (page 186) to check its current state.
The sh.getBalancerState() (page 185) method has the following parameter:
param Boolean state Set this to true to enable the balancer and false to disable it.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerHost() (page 185)
sh.getBalancerState() (page 185)
sh.isBalancerRunning() (page 186)
sh.startBalancer() (page 189)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
2.1. mongo Shell Methods 187
MongoDB Reference Manual, Release 2.6.4
sh.shardCollection()
Denition
sh.shardCollection(namespace, key, unique)
Shards a collection using the key as a the shard key. sh.shardCollection() (page 188) takes the fol-
lowing arguments:
param string namespace The namespace of the collection to shard.
param document key A document that species the shard key to use to partition and distribute
objects among the shards. A shard key may be one eld or multiple elds. A shard key with
multiple elds is called a compound shard key.
param Boolean unique When true, ensures that the underlying index enforces a unique constraint.
Hashed shard keys do not support unique constraints.
New in version 2.4: Use the form {field: "hashed"} to create a hashed shard key. Hashed shard keys
may not be compound indexes.
Considerations MongoDB provides no method to deactivate sharding for a collection after calling
shardCollection (page 307). Additionally, after shardCollection (page 307), you cannot change shard
keys or modify the value of any eld used in your shard key index.
Example Given the people collection in the records database, the following command shards the collection by
the zipcode eld:
sh.shardCollection("records.people", { zipcode: 1} )
Additional Information shardCollection (page 307) for additional options,
http://docs.mongodb.org/manualsharding and http://docs.mongodb.org/manualcore/sharding-introduction
for an overview of sharding, http://docs.mongodb.org/manualtutorial/deploy-shard-cluster
for a tutorial, and sharding-shard-key for choosing a shard key.
sh.splitAt()
Denition
sh.splitAt(namespace, query)
Splits the chunk containing the document specied by the query as if that document were at the middle of the
collection, even if the specied document is not the actual median of the collection.
param string namespace The namespace (i.e. <database>.<collection>) of the sharded
collection that contains the chunk to split.
param document query A query to identify a document in a specic chunk. Typically specify the
shard key for a document as the query.
Use this command to manually split chunks unevenly. Use the sh.splitFind() (page 189) function to
split a chunk at the actual median.
In most circumstances, you should leave chunk splitting to the automated processes within MongoDB. However,
when initially deploying a sharded cluster it is necessary to perform some measure of pre-splitting using manual
methods including sh.splitAt() (page 188).
188 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
sh.splitFind()
Denition
sh.splitFind(namespace, query)
Splits the chunk containing the document specied by the query at its median point, creating two roughly
equal chunks. Use sh.splitAt() (page 188) to split a collection in a specic point.
In most circumstances, you should leave chunk splitting to the automated processes. However, when initially
deploying a sharded cluster it is necessary to perform some measure of pre-splitting using manual methods
including sh.splitFind() (page 189).
param string namespace The namespace (i.e. <database>.<collection>) of the sharded
collection that contains the chunk to split.
param document query A query to identify a document in a specic chunk. Typically specify the
shard key for a document as the query.
sh.startBalancer()
Denition
sh.startBalancer(timeout, interval)
Enables the balancer in a sharded cluster and waits for balancing to initiate.
param integer timeout Milliseconds to wait.
param integer interval Milliseconds to sleep each cycle of waiting.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerHost() (page 185)
sh.getBalancerState() (page 185)
sh.isBalancerRunning() (page 186)
sh.setBalancerState() (page 187)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
sh.status()
Denition
sh.status()
Prints a formatted report of the sharding conguration and the information regarding existing chunks in a
sharded cluster. The default behavior suppresses the detailed chunk information if the total number of chunks
is greater than or equal to 20.
The sh.status() (page 189) method has the following parameter:
param Boolean verbose If true, the method displays details of the document distribution across
chunks when you have 20 or more chunks.
2.1. mongo Shell Methods 189
MongoDB Reference Manual, Release 2.6.4
See also:
db.printShardingStatus() (page 122)
Output Examples The Sharding Version (page 191) section displays information on the cong database:
--- Sharding Status ---
sharding version: {
"_id" : <num>,
"version" : <num>,
"minCompatibleVersion" : <num>,
"currentVersion" : <num>,
"clusterId" : <ObjectId>
}
The Shards (page 191) section lists information on the shard(s). For each shard, the section displays the name, host,
and the associated tags, if any.
shards:
{ "_id" : <shard name1>,
"host" : <string>,
"tags" : [ <string> ... ]
}
{ "_id" : <shard name2>,
"host" : <string>,
"tags" : [ <string> ... ]
}
...
The Databases (page 191) section lists information on the database(s). For each database, the section displays the
name, whether the database has sharding enabled, and the primary shard for the database.
databases:
{ "_id" : <dbname1>,
"partitioned" : <boolean>,
"primary" : <string>
}
{ "_id" : <dbname2>,
"partitioned" : <boolean>,
"primary" : <string>
}
...
The Sharded Collection (page 191) section provides information on the sharding details for sharded collection(s). For
each sharded collection, the section displays the shard key, the number of chunks per shard(s), the distribution of
documents across chunks
16
, and the tag information, if any, for shard key range(s).
<dbname>.<collection>
shard key: { <shard key> : <1 or hashed> }
chunks:
<shard name1> <number of chunks>
<shard name2> <number of chunks>
...
{ <shard key>: <min range1> } -->> { <shard key> : <max range1> } on : <shard name> <last modified timestamp>
{ <shard key>: <min range2> } -->> { <shard key> : <max range2> } on : <shard name> <last modified timestamp>
...
16
The sharded collection section, by default, displays the chunk information if the total number of chunks is less than 20. To display the
information when you have 20 or more chunks, call the sh.status() (page 189) methods with the verbose parameter set to true, i.e.
sh.status(true).
190 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
tag: <tag1> { <shard key> : <min range1> } -->> { <shard key> : <max range1> }
...
Output Fields
Sharding Version
sh.status.sharding-version._id
The _id (page 191) is an identier for the version details.
sh.status.sharding-version.version
The version (page 191) is the version of the cong server for the sharded cluster.
sh.status.sharding-version.minCompatibleVersion
The minCompatibleVersion (page 191) is the minimum compatible version of the cong server.
sh.status.sharding-version.currentVersion
The currentVersion (page 191) is the current version of the cong server.
sh.status.sharding-version.clusterId
The clusterId (page 191) is the identication for the sharded cluster.
Shards
sh.status.shards._id
The _id (page 191) displays the name of the shard.
sh.status.shards.host
The host (page 191) displays the host location of the shard.
sh.status.shards.tags
The tags (page 191) displays all the tags for the shard. The eld only displays if the shard has tags.
Databases
sh.status.databases._id
The _id (page 191) displays the name of the database.
sh.status.databases.partitioned
The partitioned (page 191) displays whether the database has sharding enabled. If true, the database has
sharding enabled.
sh.status.databases.primary
The primary (page 191) displays the primary shard for the database.
Sharded Collection
sh.status.databases.shard-key
The shard-key (page 191) displays the shard key specication document.
sh.status.databases.chunks
The chunks (page 191) lists all the shards and the number of chunks that reside on each shard.
sh.status.databases.chunk-details
The chunk-details (page 191) lists the details of the chunks
1
:
The range of shard key values that dene the chunk,
The shard where the chunk resides, and
The last modied timestamp for the chunk.
2.1. mongo Shell Methods 191
MongoDB Reference Manual, Release 2.6.4
sh.status.databases.tag
The tag (page 191) lists the details of the tags associated with a range of shard key values.
sh.stopBalancer()
Denition
sh.stopBalancer(timeout, interval)
Disables the balancer in a sharded cluster and waits for balancing to complete.
param integer timeout Milliseconds to wait.
param integer interval Milliseconds to sleep each cycle of waiting.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
sh.getBalancerHost() (page 185)
sh.getBalancerState() (page 185)
sh.isBalancerRunning() (page 186)
sh.setBalancerState() (page 187)
sh.startBalancer() (page 189)
sh.waitForBalancer() (page 192)
sh.waitForBalancerOff() (page 192)
sh.waitForBalancer()
Denition
sh.waitForBalancer(wait, timeout, interval)
Waits for a change in the state of the balancer. sh.waitForBalancer() (page 192) is an internal method,
which takes the following arguments:
param Boolean wait Set to true to ensure the balancer is nowactive. The default is false, which
waits until balancing stops and becomes inactive.
param integer timeout Milliseconds to wait.
param integer interval Milliseconds to sleep.
sh.waitForBalancerOff()
Denition
sh.waitForBalancerOff(timeout, interval)
Internal method that waits until the balancer is not running.
param integer timeout Milliseconds to wait.
param integer interval Milliseconds to sleep.
See also:
sh.enableBalancing() (page 184)
sh.disableBalancing() (page 184)
192 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
sh.getBalancerHost() (page 185)
sh.getBalancerState() (page 185)
sh.isBalancerRunning() (page 186)
sh.setBalancerState() (page 187)
sh.startBalancer() (page 189)
sh.stopBalancer() (page 192)
sh.waitForBalancer() (page 192)
sh.waitForDLock()
Denition
sh.waitForDLock(lockname, wait, timeout, interval)
Waits until the specied distributed lock changes state. sh.waitForDLock() (page 193) is an internal
method that takes the following arguments:
param string lockname The name of the distributed lock.
param Boolean wait Set to true to ensure the balancer is now active. Set to false to wait until
balancing stops and becomes inactive.
param integer timeout Milliseconds to wait.
param integer interval Milliseconds to sleep in each waiting cycle.
sh.waitForPingChange()
Denition
sh.waitForPingChange(activePings, timeout, interval)
sh.waitForPingChange() (page 193) waits for a change in ping state of one of the activepings, and
only returns when the specied ping changes state.
param array activePings An array of active pings from the mongos (page 651) collection.
param integer timeout Number of milliseconds to wait for a change in ping state.
param integer interval Number of milliseconds to sleep in each waiting cycle.
2.1. mongo Shell Methods 193
MongoDB Reference Manual, Release 2.6.4
2.1.10 Subprocess
Subprocess Methods
Name Description
clearRawMongoProgramOutput() (page 194) For internal use.
rawMongoProgramOutput() (page 194) For internal use.
run() For internal use.
runMongoProgram() (page 194) For internal use.
runProgram() (page 194) For internal use.
startMongoProgram() For internal use.
stopMongoProgram() (page 195) For internal use.
stopMongoProgramByPid() (page 195) For internal use.
stopMongod() (page 195) For internal use.
waitMongoProgramOnPort() (page 195) For internal use.
waitProgram() (page 195) For internal use.
clearRawMongoProgramOutput()
clearRawMongoProgramOutput()
For internal use.
rawMongoProgramOutput()
rawMongoProgramOutput()
For internal use.
run()
run()
For internal use.
runMongoProgram()
runMongoProgram()
For internal use.
runProgram()
runProgram()
For internal use.
startMongoProgram()
_startMongoProgram()
For internal use.
194 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
stopMongoProgram()
stopMongoProgram()
For internal use.
stopMongoProgramByPid()
stopMongoProgramByPid()
For internal use.
stopMongod()
stopMongod()
For internal use.
waitMongoProgramOnPort()
waitMongoProgramOnPort()
For internal use.
waitProgram()
waitProgram()
For internal use.
2.1.11 Constructors
Object Constructors and Methods
Name Description
BulkWriteResult() (page 196) Wrapper around the result set from Bulk.execute() (page 136).
Date() (page 197) Creates a date object. By default creates a date object including the
current date.
ObjectId.getTimestamp()
(page 197)
Returns the timestamp portion of an ObjectId.
ObjectId.toString()
(page 197)
Displays the string representation of an ObjectId.
ObjectId.valueOf()
(page 198)
Displays the str attribute of an ObjectId as a hexadecimal string.
UUID() (page 198) Converts a 32-byte hexadecimal string to the UUID BSON subtype.
WriteResult() (page 198) Wrapper around the result set from write methods.
WriteResult.hasWriteConcernError()
(page 199)
Returns a boolean specifying whether whether the results include
WriteResult.writeConcernError (page 199).
WriteResult.hasWriteError()
(page 200)
Returns a boolean specifying whether the results include
WriteResult.writeError (page 199).
2.1. mongo Shell Methods 195
MongoDB Reference Manual, Release 2.6.4
BulkWriteResult()
BulkWriteResult()
New in version 2.6.
A wrapper that contains the results of the Bulk.execute() (page 136) method.
Properties The BulkWriteResult (page 196) has the following properties:
BulkWriteResult.nInserted
The number of documents inserted using the Bulk.insert() (page 146) method. For documents inserted
through operations with the Bulk.find.upsert() (page 142) option, see the nUpserted (page 196) eld
instead.
BulkWriteResult.nMatched
The number of existing documents selected for update or replacement. If the update/replacement operation
results in no change to an existing document, e.g. $set (page 436) expression updates the value to the current
value, nMatched (page 196) can be greater than nModified (page 196).
BulkWriteResult.nModified
The number of existing documents updated or replaced. If the update/replacement operation results in no change
to an existing document, such as setting the value of the eld to its current value, nModified (page 196) can
be less than nMatched (page 196). Inserted documents do not affect the number of nModified (page 196);
refer to the nInserted (page 196) and nUpserted (page 196) elds instead.
BulkWriteResult.nRemoved
The number of documents removed.
BulkWriteResult.nUpserted
The number of documents inserted through operations with the Bulk.find.upsert() (page 142) option.
BulkWriteResult.upserted
An array of documents that contains information for each document inserted through operations with the
Bulk.find.upsert() (page 142) option.
Each document contains the following information:
BulkWriteResult.upserted.index
An integer that identies the operation in the bulk operations list, which uses a zero-based index.
BulkWriteResult.upserted._id
The _id value of the inserted document.
BulkWriteResult.writeErrors
An array of documents that contains information regarding any error, unrelated to write concerns, encountered
during the update operation. The writeErrors (page 196) array contains an error document for each write
operation that errors.
Each error document contains the following elds:
BulkWriteResult.writeErrors.index
An integer that identies the write operation in the bulk operations list, which uses a zero-based index. See
also Bulk.getOperations() (page 145).
BulkWriteResult.writeErrors.code
An integer value identifying the error.
BulkWriteResult.writeErrors.errmsg
A description of the error.
196 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
BulkWriteResult.writeErrors.op
Adocument identifying the operation that failed. For instance, an update/replace operation error will return
a document specifying the query, the update, the multi and the upsert options; an insert operation will
return the document the operation tried to insert.
BulkWriteResult.writeConcernError
Document that describe error related to write concern and contains the eld:
BulkWriteResult.writeConcernError.code
An integer value identifying the cause of the write concern error.
BulkWriteResult.writeConcernError.errInfo
A document identifying the write concern setting related to the error.
BulkWriteResult.writeConcernError.errmsg
A description of the cause of the write concern error.
Date()
Date()
Returns Current date, as a string.
ObjectId.getTimestamp()
ObjectId.getTimestamp()
Returns The timestamp portion of the ObjectId() object as a Date.
In the following example, call the getTimestamp() (page 197) method on an ObjectId (e.g.
ObjectId("507c7f79bcf86cd7994f6c0e")):
ObjectId("507c7f79bcf86cd7994f6c0e").getTimestamp()
This will return the following output:
ISODate("2012-10-15T21:26:17Z")
ObjectId.toString()
ObjectId.toString()
Returns The string representation of the ObjectId() object. This value has the format of
ObjectId(...).
Changed in version 2.2: In previous versions ObjectId.toString() (page 197) returns the value of the
ObjectId as a hexadecimal string.
In the following example, call the toString() (page 197) method on an ObjectId (e.g.
ObjectId("507c7f79bcf86cd7994f6c0e")):
ObjectId("507c7f79bcf86cd7994f6c0e").toString()
This will return the following string:
ObjectId("507c7f79bcf86cd7994f6c0e")
You can conrm the type of this object using the following operation:
2.1. mongo Shell Methods 197
MongoDB Reference Manual, Release 2.6.4
typeof ObjectId("507c7f79bcf86cd7994f6c0e").toString()
ObjectId.valueOf()
ObjectId.valueOf()
Returns The value of the ObjectId() object as a lowercase hexadecimal string. This value is the str
attribute of the ObjectId() object.
Changed in version 2.2: In previous versions ObjectId.valueOf() (page 198) returns the ObjectId()
object.
In the following example, call the valueOf() (page 198) method on an ObjectId (e.g.
ObjectId("507c7f79bcf86cd7994f6c0e")):
ObjectId("507c7f79bcf86cd7994f6c0e").valueOf()
This will return the following string:
507c7f79bcf86cd7994f6c0e
You can conrm the type of this object using the following operation:
typeof ObjectId("507c7f79bcf86cd7994f6c0e").valueOf()
UUID()
Denition
UUID(<string>)
Generates a BSON UUID object.
param string hex Specify a 32-byte hexadecimal string to convert to the UUID BSON subtype.
Returns A BSON UUID object.
Example Create a 32 byte hexadecimal string:
var myuuid = '0123456789abcdeffedcba9876543210'
Convert it to the BSON UUID subtype:
UUID(myuuid)
BinData(3,"ASNFZ4mrze/+3LqYdlQyEA==")
WriteResult()
Denition
WriteResult()
A wrapper that contains the result status of the mongo (page 580) shell write methods.
See
db.collection.insert() (page 53), db.collection.update() (page 70),
db.collection.remove() (page 64), and db.collection.save() (page 68).
198 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Properties The WriteResult (page 198) has the following properties:
WriteResult.nInserted
The number of documents inserted, excluding upserted documents. See WriteResult.nUpserted
(page 199) for the number of documents inserted through an upsert.
WriteResult.nMatched
The number of documents selected for update. If the update operation results in no change to the document, e.g.
$set (page 436) expression updates the value to the current value, nMatched (page 199) can be greater than
nModified (page 199).
WriteResult.nModified
The number of existing documents updated. If the update/replacement operation results in no change to the
document, such as setting the value of the eld to its current value, nModified (page 199) can be less than
nMatched (page 199).
WriteResult.nUpserted
The number of documents inserted by an upsert (page 72).
WriteResult._id
The _id of the document inserted by an upsert. Returned only if an upsert results in an insert.
WriteResult.nRemoved
The number of documents removed.
WriteResult.writeError
A document that contains information regarding any error, excluding write concern errors, encountered during
the write operation.
WriteResult.writeError.code
An integer value identifying the error.
WriteResult.writeError.errmsg
A description of the error.
WriteResult.writeConcernError
A document that contains information regarding any write concern errors encountered during the write opera-
tion.
WriteResult.writeConcernError.code
An integer value identifying the write concern error.
WriteResult.writeConcernError.errInfo
A document identifying the write concern setting related to the error.
WriteResult.writeError.errmsg
A description of the error.
See also:
WriteResult.hasWriteError() (page 200), WriteResult.hasWriteConcernError() (page 199)
WriteResult.hasWriteConcernError()
Denition
WriteResult.hasWriteConcernError()
Returns true if the result of a mongo (page 580) shell write method has
WriteResult.writeConcernError (page 199). Otherwise, the method returns false.
See also:
WriteResult() (page 198)
2.1. mongo Shell Methods 199
MongoDB Reference Manual, Release 2.6.4
WriteResult.hasWriteError()
Denition
WriteResult.hasWriteError()
Returns true if the result of a mongo (page 580) shell write method has WriteResult.writeError
(page 199). Otherwise, the method returns false.
See also:
WriteResult() (page 198)
2.1.12 Connection
Connection Methods
Name Description
Mongo() (page 200) Creates a new connection object.
Mongo.getDB() (page 200) Returns a database object.
Mongo.getReadPrefMode()
(page 201)
Returns the current read preference mode for the MongoDB
connection.
Mongo.getReadPrefTagSet()
(page 201)
Returns the read preference tag set for the MongoDB connection.
Mongo.setReadPref() (page 202) Sets the read preference for the MongoDB connection.
Mongo.setSlaveOk() (page 202) Allows operations on the current connection to read from secondary
members.
connect() Connects to a MongoDB instance and to a specied database on that
instance.
Mongo()
Description
Mongo(host)
JavaScript constructor to instantiate a database connection from the mongo (page 580) shell or from a JavaScript
le.
The Mongo() (page 200) method has the following parameter:
param string host The host, either in the form of <host> or <host><:port>.
Instantiation Options Use the constructor without a parameter to instantiate a connection to the localhost interface
on the default port.
Pass the <host> parameter to the constructor to instantiate a connection to the <host> and the default port.
Pass the <host><:port> parameter to the constructor to instantiate a connection to the <host> and the <port>.
See also:
Mongo.getDB() (page 200) and db.getMongo() (page 117).
Mongo.getDB()
Description
200 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Mongo.getDB(<database>)
Provides access to database objects from the mongo (page 580) shell or from a JavaScript le.
The Mongo.getDB() (page 200) method has the following parameter:
param string database The name of the database to access.
Example The following example instantiates a new connection to the MongoDB instance running on the localhost
interface and returns a reference to "myDatabase":
db = new Mongo().getDB("myDatabase");
See also:
Mongo() (page 200) and connect() (page 203)
Mongo.getReadPrefMode()
Mongo.getReadPrefMode()
Returns The current read preference mode for the Mongo() (page 117) connection object.
See http://docs.mongodb.org/manualcore/read-preference for an introduction to read pref-
erences in MongoDB. Use getReadPrefMode() (page 201) to return the current read preference mode, as
in the following example:
db.getMongo().getReadPrefMode()
Use the following operation to return and print the current read preference mode:
print(db.getMongo().getReadPrefMode());
This operation will return one of the following read preference modes:
primary
primaryPreferred
secondary
secondaryPreferred
nearest
See also:
http://docs.mongodb.org/manualcore/read-preference, readPref() (page 94),
setReadPref() (page 202), and getReadPrefTagSet() (page 201).
Mongo.getReadPrefTagSet()
Mongo.getReadPrefTagSet()
Returns The current read preference tag set for the Mongo() (page 117) connection object.
See http://docs.mongodb.org/manualcore/read-preference for an introduction to read pref-
erences and tag sets in MongoDB. Use getReadPrefTagSet() (page 201) to return the current read pref-
erence tag set, as in the following example:
2.1. mongo Shell Methods 201
MongoDB Reference Manual, Release 2.6.4
db.getMongo().getReadPrefTagSet()
Use the following operation to return and print the current read preference tag set:
printjson(db.getMongo().getReadPrefTagSet());
See also:
http://docs.mongodb.org/manualcore/read-preference, readPref() (page 94),
setReadPref() (page 202), and getReadPrefTagSet() (page 201).
Mongo.setReadPref()
Denition
Mongo.setReadPref(mode, tagSet)
Call the setReadPref() (page 202) method on a Mongo (page 117) connection object to control how the
client will route all queries to members of the replica set.
param string mode One of the following read preference modes: primary,
primaryPreferred, secondary, secondaryPreferred, or nearest.
param array tagSet A tag set used to specify custom read preference modes. For details, see
replica-set-read-preference-tag-sets.
Examples To set a read preference mode in the mongo (page 580) shell, use the following operation:
db.getMongo().setReadPref('primaryPreferred')
To set a read preference that uses a tag set, specify an array of tag sets as the second argument to
Mongo.setReadPref() (page 202), as in the following:
db.getMongo().setReadPref('primaryPreferred', [ { "dc": "east" } ] )
You can specify multiple tag sets, in order of preference, as in the following:
db.getMongo().setReadPref('secondaryPreferred',
[ { "dc": "east", "use": "production" },
{ "dc": "east", "use": "reporting" },
{ "dc": "east" },
{}
] )
If the replica set cannot satisfy the rst tag set, the client will attempt to use the second read preference. Each tag set
can contain zero or more eld/value tag pairs, with an empty document acting as a wildcard which matches a replica
set member with any tag set or no tag set.
Note: You must call Mongo.setReadPref() (page 202) on the connection object before retrieving documents
using that connection to use that read preference.
mongo.setSlaveOk()
Mongo.setSlaveOk()
For the current session, this command permits read operations from non-master (i.e. slave or secondary) in-
stances. Practically, use this method in the following form:
202 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.getMongo().setSlaveOk()
Indicates that eventually consistent read operations are acceptable for the current application. This function
provides the same functionality as rs.slaveOk() (page 177).
See the readPref() (page 94) method for more ne-grained control over read preference in the
mongo (page 580) shell.
connect()
connect(<hostname><:port>/<database>)
The connect() method creates a connection to a MongoDB instance. However, use the Mongo() (page 200)
object and its getDB() (page 200) method in most cases.
connect() accepts a string <hostname><:port>/<database> parameter to connect to the MongoDB
instance on the <hostname><:port> and return the reference to the database <database>.
The following example instantiates a new connection to the MongoDB instance running on the localhost inter-
face and returns a reference to myDatabase:
db = connect("localhost:27017/myDatabase")
See also:
Mongo.getDB() (page 200)
2.1. mongo Shell Methods 203
MongoDB Reference Manual, Release 2.6.4
2.1.13 Native
Native Methods
Name Description
_isWindows()
(page 204)
Returns true if the shell runs on a Windows system; false if a Unix or Linux
system.
_rand() (page 204) Returns a random number between 0 and 1.
_srand() (page 205) For internal use.
cat() Returns the contents of the specied le.
cd() Changes the current working directory to the specied path.
copyDbpath()
(page 205)
Copies a local dbPath. For internal use.
fuzzFile() (page 205) For internal use to support testing.
getHostName()
(page 205)
Returns the hostname of the system running the mongo (page 580) shell.
getMemInfo()
(page 205)
Returns a document that reports the amount of memory used by the shell.
hostname() Returns the hostname of the system running the shell.
listFiles() (page 206) Returns an array of documents that give the name and size of each object in the
directory.
load() Loads and runs a JavaScript le in the shell.
ls() Returns a list of the les in the current directory.
md5sumFile()
(page 206)
The md5 hash of the specied le.
mkdir() Creates a directory at the specied path.
pwd() Returns the current directory.
quit() Exits the current shell session.
removeFile()
(page 207)
Removes the specied le from the local le system.
resetDbpath()
(page 207)
Removes a local dbPath. For internal use.
version() Returns the current version of the mongo (page 580) shell instance.
_isWindows()
_isWindows()
Returns boolean.
Returns true if the mongo (page 580) shell is running on a system that is Windows, or false if the shell is
running on a Unix or Linux systems.
rand()
_rand()
Returns A random number between 0 and 1.
This function provides functionality similar to the Math.rand() function from the standard library.
204 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
_srand()
_srand()
For internal use.
cat()
Denition
cat(lename)
Returns the contents of the specied le. The method returns with output relative to the current shell session
and does not impact the server.
param string lename Specify a path and le name on the local le system.
cd()
Denition
cd(path)
param string path A path on the le system local to the mongo (page 580) shell context.
cd() changes the directory context of the mongo (page 580) shell and has no effect on the MongoDB server.
copyDbpath()
copyDbpath()
For internal use.
fuzzFile()
Description
fuzzFile(lename)
For internal use.
param string lename A lename or path to a local le.
getHostName()
getHostName()
Returns The hostname of the system running the mongo (page 580) shell process.
getMemInfo()
getMemInfo()
Returns a document with two elds that report the amount of memory used by the JavaScript shell process. The
elds returned are resident and virtual.
2.1. mongo Shell Methods 205
MongoDB Reference Manual, Release 2.6.4
hostname()
hostname()
Returns The hostname of the system running the mongo (page 580) shell process.
listFiles()
listFiles()
Returns an array, containing one document per object in the directory. This function operates in the context of
the mongo (page 580) process. The included elds are:
name
Returns a string which contains the name of the object.
isDirectory
Returns true or false if the object is a directory.
size
Returns the size of the object in bytes. This eld is only present for les.
load()
Denition
load(le)
Loads and runs a JavaScript le into the current shell environment.
The load() method has the following parameter:
param string lename Species the path of a JavaScript le to execute.
Specify lenames with relative or absolute paths. When using relative path names, conrm the current directory
using the pwd() method.
After executing a le with load(), you may reference any functions or variables dened the le from the
mongo (page 580) shell environment.
Example Consider the following examples of the load() method:
load("scripts/myjstest.js")
load("/data/db/scripts/myjstest.js")
ls()
ls()
Returns a list of the les in the current directory.
This function returns with output relative to the current shell session, and does not impact the server.
md5sumFile()
Description
206 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
md5sumFile(lename)
Returns a md5 hash of the specied le.
The md5sumFile() (page 206) method has the following parameter:
param string lename A le name.
Note: The specied lename must refer to a le located on the system running the mongo (page 580) shell.
mkdir()
Description
mkdir(path)
Creates a directory at the specied path. This method creates the entire path specied if the enclosing directory
or directories do not already exit.
This method is equivalent to mkdir -p with BSD or GNU utilities.
The mkdir() method has the following parameter:
param string path A path on the local lesystem.
pwd()
pwd()
Returns the current directory.
This function returns with output relative to the current shell session, and does not impact the server.
quit()
quit()
Exits the current shell session.
removeFile()
Description
removeFile(lename)
Removes the specied le from the local le system.
The removeFile() (page 207) method has the following parameter:
param string lename A lename or path to a local le.
resetDbpath()
resetDbpath()
For internal use.
2.1. mongo Shell Methods 207
MongoDB Reference Manual, Release 2.6.4
version()
version()
Returns The version of the mongo (page 580) shell as a string.
Changed in version 2.4: In previous versions of the shell, version() would print the version instead of
returning a string.
2.2 Database Commands
All command documentation outlined below describes a command and its available parameters and provides a doc-
ument template or prototype for each command. Some command documentation also includes the relevant mongo
(page 580) shell helpers.
2.2.1 User Commands
Aggregation Commands
Aggregation Commands
Name Description
aggregate
(page 208)
Performs aggregation tasks such as group using the aggregation framework.
count (page 211) Counts the number of documents in a collection.
distinct (page 213) Displays the distinct values found for a specied key in a collection.
group (page 214) Groups documents in a collection by the specied key and performs simple
aggregation.
mapReduce
(page 218)
Performs map-reduce aggregation for large data sets.
aggregate
aggregate
New in version 2.2.
Performs aggregation operation using the aggregation pipeline (page 458). The pipeline allows users to process
data from a collection with a sequence of stage-based manipulations.
Changed in version 2.6.
The aggregate (page 208) command adds support for returning a cursor, supports the explain option,
and enhances its sort operations with an external sort facility.
aggregation pipeline (page 458) introduces the $out (page 465) operator to allow aggregate
(page 208) command to store results to a collection.
The command has following syntax:
Changed in version 2.6.
{
aggregate: "<collection>",
pipeline: [ <stage>, <...> ],
explain: <boolean>,
208 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
allowDiskUse: <boolean>,
cursor: <document>
}
The aggregate (page 208) command takes the following elds as arguments:
eld string aggregate The name of the collection to as the input for the aggregation pipeline.
eld array pipeline An array of aggregation pipeline stages (page 458) that process and transform
the document stream as part of the aggregation pipeline.
eld boolean explain Species to return the information on the processing of the pipeline.
New in version 2.6.
eld boolean allowDiskUse Enables writing to temporary les. When set to true, aggregation
stages can write data to the _tmp subdirectory in the dbPath directory.
New in version 2.6.
eld document cursor Specify a document that contains options that control the creation of the
cursor object.
New in version 2.6.
For more information about the aggregation pipeline http://docs.mongodb.org/manualcore/aggregation-pipeline,
Aggregation Reference (page 536), and http://docs.mongodb.org/manualcore/aggregation-pipeline-limits.
Example
Aggregate Data with Multi-Stage Pipeline A collection articles contains documents such as the following:
{
_id: ObjectId("52769ea0f3dc6ead47c9a1b2"),
author: "abc123",
title: "zzz",
tags: [ "programming", "database", "mongodb" ]
}
The following example performs an aggregate (page 208) operation on the articles collection to calculate the
count of each distinct element in the tags array that appears in the collection.
db.runCommand(
{ aggregate: "articles",
pipeline: [
{ $project: { tags: 1 } },
{ $unwind: "$tags" },
{ $group: {
_id: "$tags",
count: { $sum : 1 }
}
}
]
}
)
In the mongo (page 580) shell, this operation can use the aggregate() (page 22) helper as in the following:
db.articles.aggregate(
[
{ $project: { tags: 1 } },
2.2. Database Commands 209
MongoDB Reference Manual, Release 2.6.4
{ $unwind: "$tags" },
{ $group: {
_id: "$tags",
count: { $sum : 1 }
}
}
]
)
Note: In 2.6 and later, the aggregate() (page 22) helper always returns a cursor.
Changed in version 2.4: If an error occurs, the aggregate() (page 22) helper throws an exception. In previous
versions, the helper returned a document with the error message and code, and ok status eld not equal to 1, same as
the aggregate (page 208) command.
Return Information on the Aggregation Operation The following aggregation operation sets the optional eld
explain to true to return information about the aggregation operation.
db.runCommand( { aggregate: "orders",
pipeline: [
{ $match: { status: "A" } },
{ $group: { _id: "$cust_id", total: { $sum: "$amount" } } },
{ $sort: { total: -1 } }
],
explain: true
} )
Note: The intended readers of the explain output document are humans, and not machines, and the output format
is subject to change between releases.
See also:
db.collection.aggregate() (page 22) method
Aggregate Data using External Sort Aggregation pipeline stages have maximum memory use limit. To handle large
datasets, set allowDiskUse option to true to enable writing data to temporary les, as in the following example:
db.runCommand(
{ aggregate: "stocks",
pipeline: [
{ $project : { cusip: 1, date: 1, price: 1, _id: 0 } },
{ $sort : { cusip : 1, date: 1 } }
],
allowDiskUse: true
}
)
See also:
db.collection.aggregate() (page 22)
Aggregate Command Returns a Cursor
Note: Using the aggregate (page 208) command to return a cursor is a low-level operation, intended for authors
of drivers. Most users should use the db.collection.aggregate() (page 22) helper provided in the mongo
(page 580) shell or in their driver. In 2.6 and later, the aggregate() (page 22) helper always returns a cursor.
210 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The following command returns a document that contains results with which to instantiate a cursor object.
db.runCommand(
{ aggregate: "records",
pipeline: [
{ $project: { name: 1, email: 1, _id: 0 } },
{ $sort: { name: 1 } }
],
cursor: { }
}
)
To specify an initial batch size, specify the batchSize in the cursor eld, as in the following example:
db.runCommand(
{ aggregate: "records",
pipeline: [
{ $project: { name: 1, email: 1, _id: 0 } },
{ $sort: { name: 1 } }
],
cursor: { batchSize: 0 }
}
)
The {batchSize: 0 } document species the size of the initial batch size only. Specify subsequent batch sizes
to OP_GET_MORE
17
operations as with other MongoDB cursors. A batchSize of 0 means an empty rst batch
and is useful if you want to quickly get back a cursor or failure message, without doing signicant server-side work.
See also:
db.collection.aggregate() (page 22)
count
Denition
count
Counts the number of documents in a collection. Returns a document that contains this count and as well as the
command status. count (page 211) has the following form:
Changed in version 2.6: count (page 211) now accepts the hint option to specify an index.
{ count: <collection>, query: <query>, limit: <limit>, skip: <skip>, hint: <hint> }
count (page 211) has the following elds:
eld string count The name of the collection to count.
eld document query A query that selects which documents to count in a collection.
eld integer limit The maximum number of matching documents to return.
eld integer skip The number of matching documents to skip before returning results.
eld String,document hint The index to use. Specify either the index name as a string or the index
specication document.
New in version 2.6.
17
http://docs.mongodb.org/meta-driver/latest/legacy/mongodb-wire-protocol/#wire-op-get-more
2.2. Database Commands 211
MongoDB Reference Manual, Release 2.6.4
MongoDB also provides the count() (page 81) and db.collection.count() (page 26) wrapper meth-
ods in the mongo (page 580) shell.
Behavior On a sharded cluster, count (page 211) can result in an inaccurate count if orphaned documents exist or
if a chunk migration is in progress.
To avoid these situations, on a sharded cluster, use the $group (page 460) stage of the
db.collection.aggregate() (page 22) method to $sum (page 527) the documents. For example, the
following operation counts the documents in a collection:
db.collection.aggregate(
[
{ $group: { _id: null, count: { $sum: 1 } } }
]
)
To get a count of documents that match a query condition, include the $match (page 464) stage as well:
db.collection.aggregate(
[
{ $match: <query condition> },
{ $group: { _id: null, count: { $sum: 1 } } }
]
)
See Perform a Count (page 465) for an example.
Examples The following sections provide examples of the count (page 211) command.
Count All Documents The following operation counts the number of all documents in the orders collection:
db.runCommand( { count: 'orders' } )
In the result, the n, which represents the count, is 26, and the command status ok is 1:
{ "n" : 26, "ok" : 1 }
Count Documents That Match a Query The following operation returns a count of the documents in the orders
collection where the value of the ord_dt eld is greater than Date(01/01/2012):
db.runCommand( { count:'orders',
query: { ord_dt: { $gt: new Date('01/01/2012') } }
} )
In the result, the n, which represents the count, is 13 and the command status ok is 1:
{ "n" : 13, "ok" : 1 }
Skip Documents in Count The following operation returns a count of the documents in the orders collection
where the value of the ord_dt eld is greater than Date(01/01/2012) and skip the rst 10 matching docu-
ments:
db.runCommand( { count:'orders',
query: { ord_dt: { $gt: new Date('01/01/2012') } },
skip: 10 } )
212 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
In the result, the n, which represents the count, is 3 and the command status ok is 1:
{ "n" : 3, "ok" : 1 }
Specify the Index to Use The following operation uses the index { status: 1 } to return a count of the
documents in the orders collection where the value of the ord_dt eld is greater than Date(01/01/2012)
and the status eld is equal to "D":
db.runCommand(
{
count:'orders',
query: {
ord_dt: { $gt: new Date('01/01/2012') },
status: "D"
},
hint: { status: 1 }
}
)
In the result, the n, which represents the count, is 1 and the command status ok is 1:
{ "n" : 1, "ok" : 1 }
distinct
Denition
distinct
Finds the distinct values for a specied eld across a single collection. distinct (page 213) returns a docu-
ment that contains an array of the distinct values. The return document also contains a subdocument with query
statistics and the query plan.
When possible, the distinct (page 213) command uses an index to nd documents and return values.
The command takes the following form:
{ distinct: "<collection>", key: "<field>", query: <query> }
The command contains the following elds:
eld string distinct The name of the collection to query for distinct values.
eld string key The eld to collect distinct values from.
eld document query A query specication to limit the input documents in the distinct analysis.
Examples Return an array of the distinct values of the eld ord_dt from all documents in the orders collection:
db.runCommand ( { distinct: "orders", key: "ord_dt" } )
Return an array of the distinct values of the eld sku in the subdocument item from all documents in the orders
collection:
db.runCommand ( { distinct: "orders", key: "item.sku" } )
Return an array of the distinct values of the eld ord_dt from the documents in the orders collection where the
price is greater than 10:
2.2. Database Commands 213
MongoDB Reference Manual, Release 2.6.4
db.runCommand ( { distinct: "orders",
key: "ord_dt",
query: { price: { $gt: 10 } }
} )
Note: MongoDB also provides the shell wrapper method db.collection.distinct() (page 28) for the
distinct (page 213) command. Additionally, many MongoDB drivers also provide a wrapper method. Refer to the
specic driver documentation.
group
Denition
group
Groups documents in a collection by the specied key and performs simple aggregation functions, such as
computing counts and sums. The command is analogous to a SELECT <...> GROUP BY statement in SQL.
The command returns a document with the grouped records as well as the command meta-data.
The group (page 214) command takes the following prototype form:
{
group:
{
ns: <namespace>,
key: <key>,
$reduce: <reduce function>,
$keyf: <key function>,
cond: <query>,
finalize: <finalize function>
}
}
The command accepts a document with the following elds:
eld string ns The collection from which to perform the group by operation.
eld document key The eld or elds to group. Returns a key object for use as the grouping key.
eld function $reduce An aggregation function that operates on the documents during the grouping
operation. These functions may return a sum or a count. The function takes two arguments: the
current document and an aggregation result document for that group.
eld document initial Initializes the aggregation result document.
eld function $keyf Alternative to the key eld. Species a function that creates a key object for
use as the grouping key. Use $keyf instead of key to group by calculated elds rather than
existing document elds.
eld document cond The selection criteria to determine which documents in the collection to pro-
cess. If you omit the cond eld, group (page 214) processes all the documents in the collection
for the group operation.
eld function nalize A function that runs each item in the result set before group (page 214)
returns the nal value. This function can either modify the result document or replace the result
document as a whole. Unlike the $keyf and $reduce elds that also specify a function, this
eld name is finalize, not $finalize.
214 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
For the shell, MongoDB provides a wrapper method db.collection.group() (page 47). However, the
db.collection.group() (page 47) method takes the keyf eld and the reduce eld whereas the
group (page 214) command takes the $keyf eld and the $reduce eld.
Behavior
Limits and Restrictions The group (page 214) command does not work with sharded clusters. Use the aggrega-
tion framework or map-reduce in sharded environments.
The result set must t within the maximum BSON document size (page 658).
Additionally, in version 2.2, the returned array can contain at most 20,000 elements; i.e. at most 20,000 unique
groupings. For group by operations that results in more than 20,000 unique groupings, use mapReduce (page 218).
Previous versions had a limit of 10,000 elements.
Prior to 2.4, the group (page 214) command took the mongod (page 555) instances JavaScript lock which blocked
all other JavaScript execution.
mongo Shell JavaScript Functions/Properties Changed in version 2.4.
In MongoDB 2.4, map-reduce operations (page 218), the group (page 214) command, and $where
(page 404) operator expressions cannot access certain global functions or properties, such as db, that are available in
the mongo (page 580) shell.
When upgrading to MongoDB 2.4, you will need to refactor your code if your map-reduce operations
(page 218), group (page 214) commands, or $where (page 404) operator expressions include any global shell
functions or properties that are no longer available, such as db.
The following JavaScript functions and properties are available to map-reduce operations (page 218), the
group (page 214) command, and $where (page 404) operator expressions in MongoDB 2.4:
Available Properties Available Functions
args
MaxKey
MinKey
assert()
BinData()
DBPointer()
DBRef()
doassert()
emit()
gc()
HexData()
hex_md5()
isNumber()
isObject()
ISODate()
isString()
Map()
MD5()
NumberInt()
NumberLong()
ObjectId()
print()
printjson()
printjsononeline()
sleep()
Timestamp()
tojson()
tojsononeline()
tojsonObject()
UUID()
version()
JavaScript in MongoDB
Although group (page 214) uses JavaScript, most interactions with MongoDB do not use JavaScript but use an
idiomatic driver in the language of the interacting application.
2.2. Database Commands 215
MongoDB Reference Manual, Release 2.6.4
Examples The following are examples of the db.collection.group() (page 47) method. The examples
assume an orders collection with documents of the following prototype:
{
_id: ObjectId("5085a95c8fada716c89d0021"),
ord_dt: ISODate("2012-07-01T04:00:00Z"),
ship_dt: ISODate("2012-07-02T04:00:00Z"),
item:
{
sku: "abc123",
price: 1.99,
uom: "pcs",
qty: 25
}
}
Group by Two Fields The following example groups by the ord_dt and item.sku elds those documents that
have ord_dt greater than 01/01/2012:
db.runCommand(
{
group:
{
ns: 'orders',
key: { ord_dt: 1, 'item.sku': 1 },
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
$reduce: function ( curr, result ) { },
initial: { }
}
}
)
The result is a document that contain the retval eld which contains the group by records, the count eld which
contains the total number of documents grouped, the keys eld which contains the number of unique groupings (i.e.
number of elements in the retval), and the ok eld which contains the command status:
{ "retval" :
[ { "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc456"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "bcd123"},
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "efg456"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "efg456"},
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "ijk123"},
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc456"},
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc123"},
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc456"}
],
"count" : 13,
"keys" : 11,
"ok" : 1 }
The method call is analogous to the SQL statement:
216 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
SELECT ord_dt, item_sku
FROM orders
WHERE ord_dt > '01/01/2012'
GROUP BY ord_dt, item_sku
Calculate the Sum The following example groups by the ord_dt and item.sku elds those documents that
have ord_dt greater than 01/01/2012 and calculates the sum of the qty eld for each grouping:
db.runCommand(
{ group:
{
ns: 'orders',
key: { ord_dt: 1, 'item.sku': 1 },
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
$reduce: function ( curr, result ) {
result.total += curr.item.qty;
},
initial: { total : 0 }
}
}
)
The retval eld of the returned document is an array of documents that contain the group by elds and the calculated
aggregation eld:
{ "retval" :
[ { "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "abc456", "total" : 25 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "bcd123", "total" : 10 },
{ "ord_dt" : ISODate("2012-07-01T04:00:00Z"), "item.sku" : "efg456", "total" : 10 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "efg456", "total" : 15 },
{ "ord_dt" : ISODate("2012-06-01T04:00:00Z"), "item.sku" : "ijk123", "total" : 20 },
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc123", "total" : 45 },
{ "ord_dt" : ISODate("2012-05-01T04:00:00Z"), "item.sku" : "abc456", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc123", "total" : 25 },
{ "ord_dt" : ISODate("2012-06-08T04:00:00Z"), "item.sku" : "abc456", "total" : 25 }
],
"count" : 13,
"keys" : 11,
"ok" : 1 }
The method call is analogous to the SQL statement:
SELECT ord_dt, item_sku, SUM(item_qty) as total
FROM orders
WHERE ord_dt > '01/01/2012'
GROUP BY ord_dt, item_sku
Calculate Sum, Count, and Average The following example groups by the calculated day_of_week eld, those
documents that have ord_dt greater than 01/01/2012 and calculates the sum, count, and average of the qty eld
for each grouping:
db.runCommand(
{
group:
{
2.2. Database Commands 217
MongoDB Reference Manual, Release 2.6.4
ns: 'orders',
$keyf: function(doc) {
return { day_of_week: doc.ord_dt.getDay() };
},
cond: { ord_dt: { $gt: new Date( '01/01/2012' ) } },
$reduce: function( curr, result ) {
result.total += curr.item.qty;
result.count++;
},
initial: { total : 0, count: 0 },
finalize: function(result) {
var weekdays = [
"Sunday", "Monday", "Tuesday",
"Wednesday", "Thursday",
"Friday", "Saturday"
];
result.day_of_week = weekdays[result.day_of_week];
result.avg = Math.round(result.total / result.count);
}
}
}
)
The retval eld of the returned document is an array of documents that contain the group by elds and the calculated
aggregation eld:
{
"retval" :
[
{ "day_of_week" : "Sunday", "total" : 70, "count" : 4, "avg" : 18 },
{ "day_of_week" : "Friday", "total" : 110, "count" : 6, "avg" : 18 },
{ "day_of_week" : "Tuesday", "total" : 70, "count" : 3, "avg" : 23 }
],
"count" : 13,
"keys" : 3,
"ok" : 1
}
See also:
http://docs.mongodb.org/manualcore/aggregation
mapReduce
mapReduce
The mapReduce (page 218) command allows you to run map-reduce aggregation operations over a collection.
The mapReduce (page 218) command has the following prototype form:
db.runCommand(
{
mapReduce: <collection>,
map: <function>,
reduce: <function>,
out: <output>,
query: <document>,
sort: <document>,
limit: <number>,
finalize: <function>,
scope: <document>,
218 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
jsMode: <boolean>,
verbose: <boolean>
}
)
Pass the name of the collection to the mapReduce command (i.e. <collection>) to use as the source
documents to perform the map reduce operation. The command also accepts the following parameters:
eld collection mapReduce The name of the collection on which you want to perform map-reduce.
eld Javascript function map AJavaScript function that associates or maps a value with a key
and emits the key and value pair.
See Requirements for the map Function (page 221) for more information.
eld JavaScript function reduce A JavaScript function that reduces to a single object all the
values associated with a particular key.
See Requirements for the reduce Function (page 221) for more information.
eld string or document out Species the location of the result of the map-reduce operation. You
can output to a collection, output to a collection with an action, or output inline. You may output
to a collection when performing map reduce operations on the primary members of the set; on
secondary members you may only use the inline output.
See out Options (page 222) for more information.
eld document query Species the selection criteria using query operators (page 386) for deter-
mining the documents input to the map function.
eld document sort Sorts the input documents. This option is useful for optimization. For example,
specify the sort key to be the same as the emit key so that there are fewer reduce operations. The
sort key must be in an existing index for this collection.
eld number limit Species a maximum number of documents to return from the collection.
eld Javascript function nalize Follows the reduce method and modies the output.
See Requirements for the nalize Function (page 223) for more information.
eld document scope Species global variables that are accessible in the map, reduce and
finalize functions.
eld Boolean jsMode Species whether to convert intermediate data into BSON format between
the execution of the map and reduce functions. Defaults to false.
If false:
Internally, MongoDB converts the JavaScript objects emitted by the map function to BSON
objects. These BSON objects are then converted back to JavaScript objects when calling the
reduce function.
The map-reduce operation places the intermediate BSON objects in temporary, on-disk stor-
age. This allows the map-reduce operation to execute over arbitrarily large data sets.
If true:
Internally, the JavaScript objects emitted during map function remain as JavaScript objects.
There is no need to convert the objects for the reduce function, which can result in faster
execution.
You can only use jsMode for result sets with fewer than 500,000 distinct key arguments
to the mappers emit() function.
2.2. Database Commands 219
MongoDB Reference Manual, Release 2.6.4
The jsMode defaults to false.
eld Boolean verbose Species whether to include the timing information in the result informa-
tion. The verbose defaults to true to include the timing information.
The following is a prototype usage of the mapReduce (page 218) command:
var mapFunction = function() { ... };
var reduceFunction = function(key, values) { ... };
db.runCommand(
{
mapReduce: 'orders',
map: mapFunction,
reduce: reduceFunction,
out: { merge: 'map_reduce_results', db: 'test' },
query: { ord_date: { $gt: new Date('01/01/2012') } }
}
)
JavaScript in MongoDB
Although mapReduce (page 218) uses JavaScript, most interactions with MongoDB do not use JavaScript but
use an idiomatic driver in the language of the interacting application.
Note: Changed in version 2.4.
In MongoDB 2.4, map-reduce operations (page 218), the group (page 214) command, and $where
(page 404) operator expressions cannot access certain global functions or properties, such as db, that are available in
the mongo (page 580) shell.
When upgrading to MongoDB 2.4, you will need to refactor your code if your map-reduce operations
(page 218), group (page 214) commands, or $where (page 404) operator expressions include any global shell
functions or properties that are no longer available, such as db.
The following JavaScript functions and properties are available to map-reduce operations (page 218), the
group (page 214) command, and $where (page 404) operator expressions in MongoDB 2.4:
Available Properties Available Functions
args
MaxKey
MinKey
assert()
BinData()
DBPointer()
DBRef()
doassert()
emit()
gc()
HexData()
hex_md5()
isNumber()
isObject()
ISODate()
isString()
Map()
MD5()
NumberInt()
NumberLong()
ObjectId()
print()
printjson()
printjsononeline()
sleep()
Timestamp()
tojson()
tojsononeline()
tojsonObject()
UUID()
version()
220 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Requirements for the map Function The map function has the following prototype:
function() {
...
emit(key, value);
}
The map function exhibits the following behaviors:
In the map function, reference the current document as this within the function.
The map function should not access the database for any reason.
The map function should be pure, or have no impact outside of the function (i.e. side effects.)
The emit(key,value) function associates the key with a value.
A single emit can only hold half of MongoDBs maximum BSON document size (page 658).
The map function can call emit(key,value) any number of times, including 0, per each input docu-
ment.
The following map function may call emit(key,value) either 0 or 1 times depending on the value of
the input documents status eld:
function() {
if (this.status == 'A')
emit(this.cust_id, 1);
}
The following map function may call emit(key,value) multiple times depending on the number of
elements in the input documents items eld:
function() {
this.items.forEach(function(item){ emit(item.sku, 1); });
}
The map function can access the variables dened in the scope parameter.
Requirements for the reduce Function The reduce function has the following prototype:
function(key, values) {
...
return result;
}
The reduce function exhibits the following behaviors:
The reduce function should not access the database, even to perform read operations.
The reduce function should not affect the outside system.
MongoDB will not call the reduce function for a key that has only a single value. The values argument is
an array whose elements are the value objects that are mapped to the key.
MongoDB can invoke the reduce function more than once for the same key. In this case, the previous output
from the reduce function for that key will become one of the input values to the next reduce function
invocation for that key.
The reduce function can access the variables dened in the scope parameter.
2.2. Database Commands 221
MongoDB Reference Manual, Release 2.6.4
Because it is possible to invoke the reduce function more than once for the same key, the following properties need
to be true:
the type of the return object must be identical to the type of the value emitted by the map function to ensure
that the following operations is true:
reduce(key, [ C, reduce(key, [ A, B ]) ] ) == reduce( key, [ C, A, B ] )
the reduce function must be idempotent. Ensure that the following statement is true:
reduce( key, [ reduce(key, valuesArray) ] ) == reduce( key, valuesArray )
the order of the elements in the valuesArray should not affect the output of the reduce function, so that
the following statement is true:
reduce( key, [ A, B ] ) == reduce( key, [ B, A ] )
out Options You can specify the following options for the out parameter:
Output to a Collection
out: <collectionName>
Output to a Collection with an Action This option is only available when passing out a collection that already
exists. This option is not available on secondary members of replica sets.
out: { <action>: <collectionName>
[, db: <dbName>]
[, sharded: <boolean> ]
[, nonAtomic: <boolean> ] }
When you output to a collection with an action, the out has the following parameters:
<action>: Specify one of the following actions:
replace
Replace the contents of the <collectionName> if the collection with the <collectionName> ex-
ists.
merge
Merge the new result with the existing result if the output collection already exists. If an existing document
has the same key as the new result, overwrite that existing document.
reduce
Merge the new result with the existing result if the output collection already exists. If an existing document
has the same key as the new result, apply the reduce function to both the new and the existing documents
and overwrite the existing document with the result.
db:
Optional.The name of the database that you want the map-reduce operation to write its output. By default this
will be the same database as the input collection.
sharded:
Optional. If true and you have enabled sharding on output database, the map-reduce operation will shard the
output collection using the _id eld as the shard key.
222 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
nonAtomic:
New in version 2.2.
Optional. Specify output operation as non-atomic and is valid only for merge and reduce output modes
which may take minutes to execute.
If nonAtomic is true, the post-processing step will prevent MongoDB from locking the database; however,
other clients will be able to read intermediate states of the output collection. Otherwise the map reduce operation
must lock the database during post-processing.
Output Inline Perform the map-reduce operation in memory and return the result. This option is the only available
option for out on secondary members of replica sets.
out: { inline: 1 }
The result must t within the maximum size of a BSON document (page 658).
Requirements for the finalize Function The finalize function has the following prototype:
function(key, reducedValue) {
...
return modifiedObject;
}
The finalize function receives as its arguments a key value and the reducedValue from the reduce function.
Be aware that:
The finalize function should not access the database for any reason.
The finalize function should be pure, or have no impact outside of the function (i.e. side effects.)
The finalize function can access the variables dened in the scope parameter.
Map-Reduce Examples In the mongo (page 580) shell, the db.collection.mapReduce() (page 56)
method is a wrapper around the mapReduce (page 218) command. The following examples use the
db.collection.mapReduce() (page 56) method:
Consider the following map-reduce operations on a collection orders that contains documents of the following
prototype:
{
_id: ObjectId("50a8240b927d5d8b5891743c"),
cust_id: "abc123",
ord_date: new Date("Oct 04, 2012"),
status: 'A',
price: 25,
items: [ { sku: "mmm", qty: 5, price: 2.5 },
{ sku: "nnn", qty: 5, price: 2.5 } ]
}
Return the Total Price Per Customer Perform the map-reduce operation on the orders collection to group by
the cust_id, and calculate the sum of the price for each cust_id:
1. Dene the map function to process each input document:
In the function, this refers to the document that the map-reduce operation is processing.
2.2. Database Commands 223
MongoDB Reference Manual, Release 2.6.4
The function maps the price to the cust_id for each document and emits the cust_id and price
pair.
var mapFunction1 = function() {
emit(this.cust_id, this.price);
};
2. Dene the corresponding reduce function with two arguments keyCustId and valuesPrices:
The valuesPrices is an array whose elements are the price values emitted by the map function and
grouped by keyCustId.
The function reduces the valuesPrice array to the sum of its elements.
var reduceFunction1 = function(keyCustId, valuesPrices) {
return Array.sum(valuesPrices);
};
3. Perform the map-reduce on all documents in the orders collection using the mapFunction1 map function
and the reduceFunction1 reduce function.
db.orders.mapReduce(
mapFunction1,
reduceFunction1,
{ out: "map_reduce_example" }
)
This operation outputs the results to a collection named map_reduce_example. If the
map_reduce_example collection already exists, the operation will replace the contents with the re-
sults of this map-reduce operation:
Calculate Order and Total Quantity with Average Quantity Per Item In this example, you will perform a
map-reduce operation on the orders collection for all documents that have an ord_date value greater than
01/01/2012. The operation groups by the item.sku eld, and calculates the number of orders and the total
quantity ordered for each sku. The operation concludes by calculating the average quantity per order for each sku
value:
1. Dene the map function to process each input document:
In the function, this refers to the document that the map-reduce operation is processing.
For each item, the function associates the sku with a new object value that contains the count of 1
and the item qty for the order and emits the sku and value pair.
var mapFunction2 = function() {
for (var idx = 0; idx < this.items.length; idx++) {
var key = this.items[idx].sku;
var value = {
count: 1,
qty: this.items[idx].qty
};
emit(key, value);
}
};
2. Dene the corresponding reduce function with two arguments keySKU and countObjVals:
countObjVals is an array whose elements are the objects mapped to the grouped keySKU values
passed by map function to the reducer function.
224 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The function reduces the countObjVals array to a single object reducedValue that contains the
count and the qty elds.
In reducedVal, the count eld contains the sum of the count elds from the individual array ele-
ments, and the qty eld contains the sum of the qty elds from the individual array elements.
var reduceFunction2 = function(keySKU, countObjVals) {
reducedVal = { count: 0, qty: 0 };
for (var idx = 0; idx < countObjVals.length; idx++) {
reducedVal.count += countObjVals[idx].count;
reducedVal.qty += countObjVals[idx].qty;
}
return reducedVal;
};
3. Dene a nalize function with two arguments key and reducedVal. The function modies the
reducedVal object to add a computed eld named avg and returns the modied object:
var finalizeFunction2 = function (key, reducedVal) {
reducedVal.avg = reducedVal.qty/reducedVal.count;
return reducedVal;
};
4. Perform the map-reduce operation on the orders collection using the mapFunction2,
reduceFunction2, and finalizeFunction2 functions.
db.orders.mapReduce( mapFunction2,
reduceFunction2,
{
out: { merge: "map_reduce_example" },
query: { ord_date:
{ $gt: new Date('01/01/2012') }
},
finalize: finalizeFunction2
}
)
This operation uses the query eld to select only those documents with ord_date greater than new
Date(01/01/2012). Then it output the results to a collection map_reduce_example. If the
map_reduce_example collection already exists, the operation will merge the existing contents with the
results of this map-reduce operation.
For more information and examples, see the Map-Reduce page and http://docs.mongodb.org/manualtutorial/perform-incremental-map-reduce.
Output If you set the out (page 222) parameter to write the results to a collection, the mapReduce (page 218)
command returns a document in the following form:
{
"result" : <string or document>,
"timeMillis" : <int>,
"counts" : {
"input" : <int>,
"emit" : <int>,
"reduce" : <int>,
2.2. Database Commands 225
MongoDB Reference Manual, Release 2.6.4
"output" : <int>
},
"ok" : <int>,
}
If you set the out (page 222) parameter to output the results inline, the mapReduce (page 218) command returns a
document in the following form:
{
"results" : [
{
"_id" : <key>,
"value" :<reduced or finalizedValue for key>
},
...
],
"timeMillis" : <int>,
"counts" : {
"input" : <int>,
"emit" : <int>,
"reduce" : <int>,
"output" : <int>
},
"ok" : <int>
}
mapReduce.result
For output sent to a collection, this value is either:
a string for the collection name if out (page 222) did not specify the database name, or
a document with both db and collection elds if out (page 222) specied both a database and collec-
tion name.
mapReduce.results
For output written inline, an array of resulting documents. Each resulting document contains two elds:
_id eld contains the key value,
value eld contains the reduced or nalized value for the associated key.
mapReduce.timeMillis
The command execution time in milliseconds.
mapReduce.counts
Various count statistics from the mapReduce (page 218) command.
mapReduce.counts.input
The number of documents the mapReduce (page 218) command called the map function.
mapReduce.counts.emit
The number of times the mapReduce (page 218) command called the emit function.
mapReduce.counts.reduce
The number of times the mapReduce (page 218) command called the reduce function.
mapReduce.counts.output
The number of output values produced.
mapReduce.ok
A value of 1 indicates the mapReduce (page 218) command ran successfully. A value of 0 indicates an error.
226 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Additional Information
http://docs.mongodb.org/manualtutorial/troubleshoot-map-function
http://docs.mongodb.org/manualtutorial/troubleshoot-reduce-function
db.collection.mapReduce() (page 56)
http://docs.mongodb.org/manualcore/aggregation
For a detailed comparison of the different approaches, see Aggregation Commands Comparison (page 541).
Geospatial Commands
Geospatial Commands
Name Description
geoNear (page 227) Performs a geospatial query that returns the documents closest to a given point.
geoSearch (page 231) Performs a geospatial query that uses MongoDBs haystack index functionality.
geoWalk (page 231) An internal command to support geospatial queries.
geoNear
Denition
geoNear
Species a point for which a geospatial query returns the closest documents rst. The query returns the doc-
uments from nearest to farthest. The geoNear (page 227) command provides an alternative to the $near
(page 410) operator. In addition to the functionality of $near (page 410), geoNear (page 227) returns addi-
tional diagnostic information.
The geoNear (page 227) command accepts a document that contains the following elds. Specify all distances
in the same units as the document coordinate system:
eld string geoNear The collection to query.
:eld GeoJSON point,:term:legacy coordinate pairs <legacy coordinate pairs> near:
The point for which to nd the closest documents.
eld number limit The maximum number of documents to return. The default value is 100. See
also the num option.
eld number num The num option provides the same function as the limit option. Both dene
the maximum number of documents to return. If both options are included, the num value
overrides the limit value.
eld number minDistance The minimum distance from the center point that the documents must
be. MongoDB lters the results to those documents that are at least the specied distance from
the center point.
Only available for use with 2dsphere index.
Specify the distance in meters for GeoJSON data and in radians for legacy coordinate pairs.
New in version 2.6.
eld number maxDistance The maximum distance from the center point that the documents can
be. MongoDB limits the results to those documents that fall within the specied distance from
the center point.
2.2. Database Commands 227
MongoDB Reference Manual, Release 2.6.4
Specify the distance in meters for GeoJSON data and in radians for legacy coordinate pairs.
eld document query Limits the results to the documents that match the query. The query syntax
is the usual MongoDB read operation query syntax.
You cannot specify a $near (page 410) predicate in the query eld of the geoNear
(page 227) command.
eld Boolean spherical Required if using a 2dsphere index. For use with 2dsphere indexes,
spherical must be true.
The default value is false.
eld number distanceMultiplier The factor to multiply all distances returned by the query. For
example, use the distanceMultiplier to convert radians, as returned by a spherical query,
to kilometers by multiplying by the radius of the Earth.
eld Boolean includeLocs If this is true, the query returns the location of the matching documents
in the results. The default is false. This option is useful when a location eld contains multiple
locations. To specify a eld within a subdocument, use dot notation.
eld Boolean uniqueDocs If this value is true, the query returns a matching document once, even
if more than one of the documents location elds match the query.
Deprecated since version 2.6: Geospatial queries no longer return duplicate results. The
$uniqueDocs (page 416) operator has no impact on results.
Considerations The geoNear (page 227) command can use either a GeoJSON point or legacy coordinate pairs.
Queries that use a 2d index return a limit of 100 documents.
The geoNear (page 227) command requires that a collection have at most only one 2d index and/or only one
2dsphere.
You cannot specify a $near (page 410) predicate in the query eld of the geoNear (page 227) command.
Behavior geoNear (page 227) always returns the documents sorted by distance. Any other sort order requires
to sort the documents in memory, which can be inefcient. To return results in a different sort order, use the
$geoWithin (page 407) operator and the sort() method.
Because geoNear (page 227) orders the documents from nearest to farthest, the minDistance eld effectively
skips over the rst n documents where n is determined by the distance requirement.
Command Format
2dsphere Index To query a 2dsphere index, use the following syntax:
db.runCommand( {
geoNear: <collection> ,
near: { type: "Point" , coordinates: [ <coordinates> ] } ,
spherical: true,
...
} )
You must include spherical: true.
228 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
2d Index To query a 2d index, use:
db.runCommand( {
geoNear: <collection>,
near : [ <coordinates> ],
...
} )
Examples The following examples run the geoNear (page 227) command on the collection places that has a
2dsphere index.
Specify a Query Condition The following geoNear (page 227) command queries for documents whose
category equals "public" and returns the matching documents in order of nearest to farthest to the specied
point:
db.runCommand(
{
geoNear: "places",
near: { type: "Point", coordinates: [ -73.9667, 40.78 ] },
spherical: true,
query: { category: "public" }
}
)
The operation returns the following output, the documents in the results from nearest to farthest:
{
"results" : [
{
"dis" : 0,
"obj" : {
"_id" : 2,
"location" : { "type" : "Point", "coordinates" : [ -73.9667, 40.78 ] },
"name" : "Central Park",
"category" : "public"
}
},
{
"dis" : 3245.988787957091,
"obj" : {
"_id" : 3,
"location" : { "type" : "Point", "coordinates" : [ -73.9836, 40.7538 ] },
"name" : "Bryant Park",
"category" : "public"
}
},
{
"dis" : 7106.506152782733,
"obj" : {
"_id" : 4,
"location" : { "type" : "Point", "coordinates" : [ -73.9928, 40.7193 ] },
"name" : "Sara D. Roosevelt Park",
"category" : "public"
}
},
],
2.2. Database Commands 229
MongoDB Reference Manual, Release 2.6.4
"stats" : {
"nscanned" : NumberLong(47),
"objectsLoaded" : NumberLong(47),
"avgDistance" : 3450.8316469132747,
"maxDistance" : 7106.506152782733,
"time" : 4
},
"ok" : 1
}
Specify a minDistance and maxDistance The following example species a minDistance of 3000 meters
and maxDistance of 7000 meters:
db.runCommand(
{
geoNear: "places",
near: { type: "Point", coordinates: [ -73.9667, 40.78 ] },
spherical: true,
query: { category: "public" },
minDistance: 3000,
maxDistance: 7000
}
)
The operation returns the following output:
{
"results" : [
{
"dis" : 3245.988787957091,
"obj" : {
"_id" : 3,
"location" : { "type" : "Point", "coordinates" : [ -73.9836, 40.7538 ] },
"name" : "Bryant Park",
"category" : "public"
}
}
],
"stats" : {
"nscanned" : NumberLong(11),
"objectsLoaded" : NumberLong(11),
"avgDistance" : 3245.988787957091,
"maxDistance" : 3245.988787957091,
"time" : 0
},
"ok" : 1
}
Output The geoNear (page 227) command returns a document with the following elds:
geoNear.results
An array with the results of the geoNear (page 227) command, sorted by distance with the nearest result listed
rst and farthest last.
geoNear.results[n].dis
For each document in the results, the distance from the coordinates dened in the geoNear (page 227) com-
mand.
230 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
geoNear.results[n].obj
The document from the collection.
geoNear.stats
An object with statistics about the query used to return the results of the geoNear (page 227) search.
geoNear.stats.nscanned
The total number of index entries scanned during the database operation.
geoNear.stats.objectsLoaded
The total number of documents read from disk during the database operation.
geoNear.stats.avgDistance
The average distance between the coordinates dened in the geoNear (page 227) command and coordinates
of the documents returned as results.
geoNear.stats.maxDistance
The maximum distance between the coordinates dened in the geoNear (page 227) command and coordinates
of the documents returned as results.
geoNear.stats.time
The execution time of the database operation, in milliseconds.
geoNear.ok
A value of 1 indicates the geoNear (page 227) search succeeded. A value of 0 indicates an error.
geoSearch
geoSearch
The geoSearch (page 231) command provides an interface to MongoDBs haystack index functionality. These
indexes are useful for returning results based on location coordinates after collecting results based on some other
query (i.e. a haystack.) Consider the following example:
{ geoSearch : "places", near : [33, 33], maxDistance : 6, search : { type : "restaurant" }, limit : 30 }
The above command returns all documents with a type of restaurant having a maximum distance of 6
units from the coordinates [30,33] in the collection places up to a maximum of 30 results.
Unless specied otherwise, the geoSearch (page 231) command limits results to 50 documents.
Important: geoSearch (page 231) is not supported for sharded clusters.
geoWalk
geoWalk
geoWalk (page 231) is an internal command.
2.2. Database Commands 231
MongoDB Reference Manual, Release 2.6.4
Query and Write Operation Commands
Query and Write Operation Commands
Name Description
delete (page 232) Deletes one or more documents.
eval (page 235) Runs a JavaScript function on the database server.
findAndModify (page 237) Returns and modies a single document.
getLastError (page 243) Returns the success status of the last operation.
getPrevError (page 245) Returns status document containing all errors since the last resetError
(page 248) command.
insert (page 245) Inserts one or more documents.
parallelCollectionScan
(page 247)
Lets applications use multiple parallel cursors when reading documents
from a collection.
resetError (page 248) Resets the last error status.
text (page 248) Performs a text search.
update (page 249) Updates one or more documents.
delete
Denition
delete
New in version 2.6.
The delete (page 232) command removes documents from a collection. A single delete (page 232) com-
mand can contain multiple delete specications. The command cannot operate on capped collections.
The remove methods provided by the MongoDB drivers use this command internally.
The delete (page 232) command has the following syntax:
{
delete: <collection>,
deletes: [
{ q : <query>, limit : <integer> },
{ q : <query>, limit : <integer> },
{ q : <query>, limit : <integer> },
...
],
ordered: <boolean>,
writeConcern: { <write concern> }
}
The command takes the following elds:
eld string delete The name of the target collection.
eld array deletes An array of one or more delete statements to perform in the named collection.
eld boolean ordered If true, then when a delete statement fails, return without performing the
remaining delete statements. If false, then when a delete statement fails, continue with the
remaining delete statements, if any. Defaults to true.
eld document writeConcern A document expressing the write concern of the delete
(page 232) command. Omit to use the default write concern.
Each element of the deletes array contains the following sub-elds:
eld string q The query that matches documents to delete.
232 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld integer limit The number of matching documents to delete. Specify either a 0 to delete all
matching documents or 1 to delete a single document.
Returns A document that contains the status of the operation. See Output (page 234) for details.
Behavior The total size of all the queries (i.e. the q eld values) in the deletes array must be less than or equal
to the maximum BSON document size (page 658).
The total number of delete documents in the deletes array must be less than or equal to the maximum bulk
size.
Examples
Limit the Number of Documents Deleted The following example deletes from the orders collection one docu-
ment that has the status equal to D by specifying the limit of 1:
db.runCommand(
{
delete: "orders",
deletes: [ { q: { status: "D" }, limit: 1 } ]
}
)
The returned document shows that the command deleted 1 document. See Output (page 234) for details.
{ "ok" : 1, "n" : 1 }
Delete All Documents That Match a Condition The following example deletes from the orders collection all
documents that have the status equal to D by specifying the limit of 0:
db.runCommand(
{
delete: "orders",
deletes: [ { q: { status: "D" }, limit: 0 } ],
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
The returned document shows that the command found and deleted 13 documents. See Output (page 234) for details.
{ "ok" : 1, "n" : 13 }
Delete All Documents from a Collection Delete all documents in the orders collection by specifying an empty
query condition and a limit of 0:
db.runCommand(
{
delete: "orders",
deletes: [ { q: { }, limit: 0 } ],
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
The returned document shows that the command found and deleted 35 documents in total. See Output (page 234) for
details.
2.2. Database Commands 233
MongoDB Reference Manual, Release 2.6.4
{ "ok" : 1, "n" : 35 }
Bulk Delete The following example performs multiple delete operations on the orders collection:
db.runCommand(
{
delete: "orders",
deletes: [
{ q: { status: "D" }, limit: 0 },
{ q: { cust_num: 99999, item: "abc123", status: "A" }, limit: 1 }
],
ordered: false,
writeConcern: { w: 1 }
}
)
The returned document shows that the command found and deleted 21 documents in total for the two delete statements.
See Output (page 234) for details.
{ "ok" : 1, "n" : 21 }
Output The returned document contains a subset of the following elds:
delete.ok
The status of the command.
delete.n
The number of documents deleted.
delete.writeErrors
An array of documents that contains information regarding any error encountered during the delete operation.
The writeErrors (page 234) array contains an error document for each delete statement that errors.
Each error document contains the following information:
delete.writeErrors.index
An integer that identies the delete statement in the deletes array, which uses a zero-based index.
delete.writeErrors.code
An integer value identifying the error.
delete.writeErrors.errmsg
A description of the error.
delete.writeConcernError
Document that describe error related to write concern and contains the eld:
delete.writeConcernError.code
An integer value identifying the cause of the write concern error.
delete.writeConcernError.errmsg
A description of the cause of the write concern error.
The following is an example document returned for a successful delete (page 232) command:
{ ok: 1, n: 1 }
The following is an example document returned for a delete (page 232) command that encountered an error:
234 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
"ok" : 1,
"n" : 0,
"writeErrors" : [
{
"index" : 0,
"code" : 10101,
"errmsg" : "can't remove from a capped collection: test.cappedLog"
}
]
}
eval
eval
The eval (page 235) command evaluates JavaScript functions on the database server.
The eval (page 235) command has the following form:
{
eval: <function>,
args: [ <arg1>, <arg2> ... ],
nolock: <boolean>
}
The command contains the following elds:
eld function eval A JavaScript function.
eld array args An array of arguments to pass to the JavaScript function. Omit if the function does
not take arguments.
eld boolean nolock By default, eval (page 235) takes a global write lock before evaluating the
JavaScript function. As a result, eval (page 235) blocks all other read and write operations to
the database while the eval (page 235) operation runs. Set nolock to true on the eval
(page 235) command to prevent the eval (page 235) command from taking the global write
lock before evaluating the JavaScript. nolock does not impact whether operations within the
JavaScript code itself takes a write lock.
JavaScript in MongoDB
Although eval (page 235) uses JavaScript, most interactions with MongoDB do not use JavaScript but use an
idiomatic driver in the language of the interacting application.
Behavior
Write Lock By default, eval (page 235) takes a global write lock while evaluating the JavaScript function. As a
result, eval (page 235) blocks all other read and write operations to the database while the eval (page 235) operation
runs.
To prevent the taking of the global write lock while evaluating the JavaScript code, use the eval (page 235) command
with nolock set to true. nolock does not impact whether the operations within the JavaScript code take write
locks.
For long running eval (page 235) operation, consider using either the eval command with nolock: true or
using other server side code execution options.
2.2. Database Commands 235
MongoDB Reference Manual, Release 2.6.4
Sharded Data You can not use eval (page 235) with sharded collections. In general, you should avoid using eval
(page 235) in sharded clusters; nevertheless, it is possible to use eval (page 235) with non-sharded collections and
databases stored in a sharded cluster.
Access Control Changed in version 2.6.
If authorization is enabled, you must have access to all actions on all resources in order to run eval (page 235).
Providing such access is not recommended, but if your organization requires a user to run eval (page 235), create a
role that grants anyAction on resource-anyresource. Do not assign this role to any other user.
JavaScript Engine Changed in version 2.4.
The V8 JavaScript engine, which became the default in 2.4, allows multiple JavaScript operations to execute at the
same time. Prior to 2.4, eval (page 235) executed in a single thread.
Example The following example uses eval (page 235) to perform an increment and calculate the average on the
server:
db.runCommand( {
eval: function(name, incAmount) {
var doc = db.myCollection.findOne( { name : name } );
doc = doc || { name : name , num : 0 , total : 0 , avg : 0 };
doc.num++;
doc.total += incAmount;
doc.avg = doc.total / doc.num;
db.myCollection.save( doc );
return doc;
},
args: [ "eliot", 5 ]
}
);
The db in the function refers to the current database.
The mongo (page 580) shell provides a helper method db.eval() (page 113)
18
, so you can express the above as
follows:
db.eval( function(name, incAmount) {
var doc = db.myCollection.findOne( { name : name } );
doc = doc || { name : name , num : 0 , total : 0 , avg : 0 };
doc.num++;
doc.total += incAmount;
doc.avg = doc.total / doc.num;
db.myCollection.save( doc );
return doc;
},
"eliot", 5 );
18
The helper db.eval() (page 113) in the mongo (page 580) shell wraps the eval (page 235) command. Therefore, the helper method shares
the characteristics and behavior of the underlying command with one exception: db.eval() (page 113) method does not support the nolock
option.
236 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
If you want to use the servers interpreter, you must run eval (page 235). Otherwise, the mongo (page 580) shells
JavaScript interpreter evaluates functions entered directly into the shell.
If an error occurs, eval (page 235) throws an exception. The following invalid function uses the variable x without
declaring it as an argument:
db.runCommand(
{
eval: function() { return x + x; },
args: [ 3 ]
}
)
The statement will result in the following exception:
{
"errmsg" : "exception: JavaScript execution failed: ReferenceError: x is not defined near '{ return x + x; }' ",
"code" : 16722,
"ok" : 0
}
See also:
http://docs.mongodb.org/manualcore/server-side-javascript
ndAndModify
Denition
findAndModify
The findAndModify (page 237) command modies and returns a single document. By default, the returned
document does not include the modications made on the update. To return the document with the modications
made on the update, use the new option.
The command has the following syntax:
{
findAndModify: <string>,
query: <document>,
sort: <document>,
remove: <boolean>,
update: <document>,
new: <boolean>,
fields: <document>,
upsert: <boolean>
}
The findAndModify (page 237) command takes the following elds:
eld string ndAndModify The collection against which to run the command.
param document query The selection criteria for the modication. The query eld employs the
same query selectors (page 386) as used in the db.collection.find() (page 33) method.
Although the query may match multiple documents, findAndModify (page 237) will select
only one document to modify.
param document sort Determines which document the operation modies if the query selects mul-
tiple documents. findAndModify (page 237) modies the rst document in the sort order
specied by this argument.
2.2. Database Commands 237
MongoDB Reference Manual, Release 2.6.4
param Boolean remove Must specify either the remove or the update eld. Removes the doc-
ument specied in the query eld. Set this to true to remove the selected document . The
default is false.
param document update Must specify either the remove or the update eld. Performs an up-
date of the selected document. The update eld employs the same update operators (page 429)
or field: value specications to modify the selected document.
param Boolean new When true, returns the modied document rather than the original. The
findAndModify (page 237) method ignores the new option for remove operations. The
default is false.
param document elds A subset of elds to return. The fields document species an inclusion
of a eld with 1, as in: fields: { <field1>: 1, <field2>: 1, ... }. See
projection.
param Boolean upsert Used in conjunction with the update eld.
When true, findAndModify (page 237) creates a new document if no document matches
the query, or if documents match the query, findAndModify (page 237) performs an
update.
The default is false.
Output The return document contains the following elds:
The lastErrorObject eld that returns the details of the command:
The updatedExisting eld only appears if the command species an update or an update with
upsert: true; i.e. the eld does not appear for a remove.
The upserted eld only appears if the update with the upsert: true operation results in an
insertion.
The value eld that returns either:
the original (i.e. pre-modication) document if new is false, or
the modied or inserted document if new: true.
The ok eld that returns the status of the command.
Note: If the findAndModify (page 237) nds no matching document, then:
for update or remove operations, lastErrorObject does not appear in the return document and the
value eld holds a null.
{ "value" : null, "ok" : 1 }
for update with upsert: true operation that results in an insertion, if the command also species new
is false and species a sort, the return document has a lastErrorObject, value, and ok elds, but
the value eld holds an empty document {}.
for update with upsert: true operation that results in an insertion, if the command also species new is
false but does not specify a sort, the return document has a lastErrorObject, value, and ok elds,
but the value eld holds a null.
Behavior When the findAndModify (page 237) command includes the upsert: true option and the query
eld(s) is not uniquely indexed, the command could insert a document multiple times in certain circumstances. For
238 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
instance, if multiple clients issue the findAndModify (page 237) command and these commands complete the
find phase before any one starts the modify phase, these commands could insert the same document.
Consider an example where no document with the name Andy exists and multiple clients issue the following com-
mand:
db.runCommand(
{
findAndModify: "people",
query: { name: "Andy" },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true
}
)
If all the commands nish the query phase before any command starts the modify phase, and there is no unique
index on the name eld, the commands may all result in an insert. To prevent this condition, create a unique index
on the name eld. With the unique index in place, then the multiple findAndModify (page 237) commands would
observe one of the following behaviors:
Exactly one findAndModify (page 237) would successfully insert a new document.
Zero or more findAndModify (page 237) commands would update the newly inserted document.
Zero or more findAndModify (page 237) commands would fail when they attempted to insert a duplicate.
If the command fails due to a unique index constraint violation, you can retry the command. Absent a delete of
the document, the retry should not fail.
Sharded Collections When using findAndModify (page 237) in a sharded environment, the query must con-
tain the shard key for all operations against the shard cluster. findAndModify (page 237) operations issued against
mongos (page 571) instances for non-sharded collections function normally.
Concurrency This command obtains a write lock on the affected database and will block other operations until it
has completed; however, typically the write lock is short lived and equivalent to other similar update() (page 70)
operations.
Comparisons with the update Method When updating a document, findAndModify (page 237) and the
update() (page 70) method operate differently:
By default, both operations modify a single document. However, the update() (page 70) method with its
multi option can modify more than one document.
If multiple documents match the update criteria, for findAndModify (page 237), you can specify a sort to
provide some measure of control on which document to update.
With the default behavior of the update() (page 70) method, you cannot specify which single document to
update when multiple documents match.
By default, findAndModify (page 237) method returns an object that contains the pre-modied version of
the document, as well as the status of the operation. To obtain the updated document, use the new option.
The update() (page 70) method returns a WriteResult (page 198) object that contains the status of the
operation. To return the updated document, use the find() (page 33) method. However, other updates may
have modied the document between your update and the document retrieval. Also, if the update modied only
a single document but multiple documents matched, you will need to use additional logic to identify the updated
document.
2.2. Database Commands 239
MongoDB Reference Manual, Release 2.6.4
You cannot specify a write concern to findAndModify (page 237) to override the default write concern
whereas, starting in MongoDB 2.6, you can specify a write concern to the update() (page 70) method.
When modifying a single document, both findAndModify (page 237) and
the update() (page 70) method atomically update the document. See
http://docs.mongodb.org/manualtutorial/isolate-sequence-of-operations for more
details about interactions and order of operations of these methods.
Examples
Update and Return The following command updates an existing document in the people collection where the
document matches the query criteria:
db.runCommand(
{
findAndModify: "people",
query: { name: "Tom", state: "active", rating: { $gt: 10 } },
sort: { rating: 1 },
update: { $inc: { score: 1 } }
}
)
This command performs the following actions:
1. The query nds a document in the people collection where the name eld has the value Tom, the state
eld has the value active and the rating eld has a value greater than (page 386) 10.
2. The sort orders the results of the query in ascending order. If multiple documents meet the query condition,
the command will select for modication the rst document as ordered by this sort.
3. The update increments the value of the score eld by 1.
4. The command returns a document with the following elds:
The lastErrorObject eld that contains the details of the command, including the eld
updatedExisting which is true, and
The value eld that contains the original (i.e. pre-modication) document selected for this update:
{
"lastErrorObject" : {
"updatedExisting" : true,
"n" : 1,
"connectionId" : 1,
"err" : null,
"ok" : 1
},
"value" : {
"_id" : ObjectId("50f1d54e9beb36a0f45c6452"),
"name" : "Tom",
"state" : "active",
"rating" : 100,
"score" : 5
},
"ok" : 1
}
To return the modied document in the value eld, add the new:true option to the command.
If no document match the query condition, the command returns a document that contains null in the value eld:
240 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "value" : null, "ok" : 1 }
The mongo (page 580) shell and many drivers provide a findAndModify() (page 38) helper method. Using the
shell helper, this previous operation can take the following form:
db.people.findAndModify( {
query: { name: "Tom", state: "active", rating: { $gt: 10 } },
sort: { rating: 1 },
update: { $inc: { score: 1 } }
} );
However, the findAndModify() (page 38) shell helper method returns only the unmodied document, or if new
is true, the modied document.
{
"_id" : ObjectId("50f1d54e9beb36a0f45c6452"),
"name" : "Tom",
"state" : "active",
"rating" : 100,
"score" : 5
}
upsert: true The following findAndModify (page 237) command includes the upsert: true option
for the update operation to either update a matching document or, if no matching document exists, create a new
document:
db.runCommand(
{
findAndModify: "people",
query: { name: "Gus", state: "active", rating: 100 },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true
}
)
If the command nds a matching document, the command performs an update.
If the command does not nd a matching document, the update with upsert: true operation results in an insertion
and returns a document with the following elds:
The lastErrorObject eld that contains the details of the command, including the eld upserted that
contains the ObjectId of the newly inserted document, and
The value eld that contains an empty document {} as the original document because the command included
the sort option:
{
"lastErrorObject" : {
"updatedExisting" : false,
"upserted" : ObjectId("50f2329d0092b46dae1dc98e"),
"n" : 1,
"connectionId" : 1,
"err" : null,
"ok" : 1
},
"value" : {
},
2.2. Database Commands 241
MongoDB Reference Manual, Release 2.6.4
"ok" : 1
}
If the command did not include the sort option, the value eld would contain null:
{
"value" : null,
"lastErrorObject" : {
"updatedExisting" : false,
"n" : 1,
"upserted" : ObjectId("5102f7540cb5c8be998c2e99")
},
"ok" : 1
}
Return New Document The following findAndModify (page 237) command includes both upsert: true
option and the new:true option. The command either updates a matching document and returns the updated docu-
ment or, if no matching document exists, inserts a document and returns the newly inserted document in the value
eld.
In the following example, no document in the people collection matches the query condition:
db.runCommand(
{
findAndModify: "people",
query: { name: "Pascal", state: "active", rating: 25 },
sort: { rating: 1 },
update: { $inc: { score: 1 } },
upsert: true,
new: true
}
)
The command returns the newly inserted document in the value eld:
{
"lastErrorObject" : {
"updatedExisting" : false,
"upserted" : ObjectId("50f47909444c11ac2448a5ce"),
"n" : 1,
"connectionId" : 1,
"err" : null,
"ok" : 1
},
"value" : {
"_id" : ObjectId("50f47909444c11ac2448a5ce"),
"name" : "Pascal",
"rating" : 25,
"score" : 1,
"state" : "active"
},
"ok" : 1
}
getLastError
242 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Denition
getLastError
Changed in version 2.6: A new protocol for write operations (page 687) integrates write concerns with the write
operations, eliminating the need for a separate getLastError (page 243) command. Write methods now
return the status of the write operation, including error information.
In previous versions, clients typically used the getLastError (page 243) command in combination with the
write operations to ensure that the write succeeds.
Returns the error status of the preceding write operation on the current connection.
getLastError (page 243) uses the following prototype form:
{ getLastError: 1 }
getLastError (page 243) uses the following elds:
eld Boolean j If true, wait for the next journal commit before returning, rather than waiting for
a full disk ush. If mongod (page 555) does not have journaling enabled, this option has no
effect. If this option is enabled for a write operation, mongod (page 555) will wait no more than
1/3 of the current commitIntervalMs before writing data to the journal.
eld integer,string w When running with replication, this is the number of servers to replicate to
before returning. A w value of 1 indicates the primary only. A w value of 2 includes the primary
and at least one secondary, etc. In place of a number, you may also set w to majority to
indicate that the command should wait until the latest write propagates to a majority of replica
set members. If using w, you should also use wtimeout. Specifying a value for w without also
providing a wtimeout may cause getLastError (page 243) to block indenitely.
eld Boolean fsync If true, wait for mongod (page 555) to write this data to disk before returning.
Defaults to false. In most cases, use the j option to ensure durability and consistency of the data
set.
eld integer wtimeout Milliseconds. Specify a value in milliseconds to control how long to wait
for write propagation to complete. If replication does not complete in the given timeframe, the
getLastError (page 243) command will return with an error status.
See also:
Write Concern, http://docs.mongodb.org/manualreference/write-concern, and
replica-set-write-concern.
Output Each getLastError() command returns a document containing a subset of the elds listed below.
getLastError.ok
ok (page 243) is true when the getLastError (page 243) command completes successfully.
Note: A value of true does not indicate that the preceding operation did not produce an error.
getLastError.err
err (page 243) is null unless an error occurs. When there was an error with the preceding operation, err
contains a textual description of the error.
getLastError.code
code (page 243) reports the preceding operations error code.
getLastError.connectionId
The identier of the connection.
2.2. Database Commands 243
MongoDB Reference Manual, Release 2.6.4
getLastError.lastOp
When issued against a replica set member and the preceding operation was a write or update, lastOp
(page 243) is the optime timestamp in the oplog of the change.
getLastError.n
n (page 244) reports the number of documents updated or removed, if the preceding operation was an update or
remove operation.
getLastError.shards
When issued against a sharded cluster after a write operation, shards (page 244) identies the shards targeted
in the write operation. shards (page 244) is present in the output only if the write operation targets multiple
shards.
getLastError.singleShard
When issued against a sharded cluster after a write operation, identies the shard targeted in the write operation.
singleShard (page 244) is only present if the write operation targets exactly one shard.
getLastError.updatedExisting
updatedExisting (page 244) is true when an update affects at least one document and does not result in
an upsert.
getLastError.upserted
If the update results in an insert, upserted (page 244) is the value of _id eld of the document.
Changed in version 2.6: Earlier versions of MongoDB included upserted (page 244) only if _id was an
ObjectId.
getLastError.wnote
If set, wnote indicates that the preceding operations error relates to using the w parameter to getLastError
(page 243).
See
http://docs.mongodb.org/manualreference/write-concern for more information about w
values.
getLastError.wtimeout
wtimeout (page 244) is true if the getLastError (page 243) timed out because of the wtimeout setting
to getLastError (page 243).
getLastError.waited
If the preceding operation specied a timeout using the wtimeout setting to getLastError (page 243),
then waited (page 244) reports the number of milliseconds getLastError (page 243) waited before timing
out.
getLastError.wtime
getLastError.wtime (page 244) is the number of milliseconds spent waiting for the preceding operation
to complete. If getLastError (page 243) timed out, wtime (page 244) and getLastError.waited are
equal.
Examples
Conrm Replication to Two Replica Set Members The following example ensures the operation has replicated to
two members (the primary and one other member):
db.runCommand( { getLastError: 1, w: 2 } )
244 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Conrm Replication to a Majority of a Replica Set The following example ensures the write operation has repli-
cated to a majority of the congured members of the set.
db.runCommand( { getLastError: 1, w: "majority" } )
Changed in version 2.6: In Master/Slave deployments, MongoDB treats w: "majority" as equivalent to w:
1. In earlier versions of MongoDB, w: "majority" produces an error in master/slave deployments.
Set a Timeout for a getLastError Response Unless you specify a timeout, a getLastError (page 243)
command may block forever if MongoDB cannot satisfy the requested write concern. To specify a timeout of 5000
milliseconds, use an invocation that resembles the following:
db.runCommand( { getLastError: 1, w: 2, wtimeout:5000 } )
When wtimeout is 0, the getLastError (page 243) operation will never time out.
getPrevError
getPrevError
The getPrevError (page 245) command returns the errors since the last resetError (page 248) com-
mand.
See also:
db.getPrevError() (page 117)
insert
Denition
insert
New in version 2.6.
The insert (page 245) command inserts one or more documents and returns a document containing the status
of all inserts. The insert methods provided by the MongoDB drivers use this command internally.
The command has the following syntax:
{
insert: <collection>,
documents: [ <document>, <document>, <document>, ... ],
ordered: <boolean>,
writeConcern: { <write concern> }
}
The insert (page 245) command takes the following elds:
eld string insert The name of the target collection.
eld array documents An array of one or more documents to insert into the named collection.
eld boolean ordered If true, then when an insert of a document fails, return without inserting
any remaining documents listed in the inserts array. If false, then when an insert of a
document fails, continue to insert the remaining documents. Defaults to true.
eld document writeConcern A document expressing the write concern of the insert
(page 245) command. Omit to use the default write concern.
Returns A document that contains the status of the operation. See Output (page 246) for details.
2.2. Database Commands 245
MongoDB Reference Manual, Release 2.6.4
Behavior The total size of all the documents array elements must be less than or equal to the maximum BSON
document size (page 658).
The total number of documents in the documents array must be less than or equal to the maximum bulk size.
Examples
Insert a Single Document Insert a document into the users collection:
db.runCommand(
{
insert: "users",
documents: [ { _id: 1, user: "abc123", status: "A" } ]
}
)
The returned document shows that the command successfully inserted a document. See Output (page 246) for details.
{ "ok" : 1, "n" : 1 }
Bulk Insert Insert three documents into the users collection:
db.runCommand(
{
insert: "users",
documents: [
{ _id: 2, user: "ijk123", status: "A" },
{ _id: 3, user: "xyz123", status: "P" },
{ _id: 4, user: "mop123", status: "P" }
],
ordered: false,
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
The returned document shows that the command successfully inserted the three documents. See Output (page 246) for
details.
{ "ok" : 1, "n" : 3 }
Output The returned document contains a subset of the following elds:
insert.ok
The status of the command.
insert.n
The number of documents inserted.
insert.writeErrors
An array of documents that contains information regarding any error encountered during the insert operation.
The writeErrors (page 246) array contains an error document for each insert that errors.
Each error document contains the following elds:
insert.writeErrors.index
An integer that identies the document in the documents array, which uses a zero-based index.
246 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
insert.writeErrors.code
An integer value identifying the error.
insert.writeErrors.errmsg
A description of the error.
insert.writeConcernError
Document that describe error related to write concern and contains the eld:
insert.writeConcernError.code
An integer value identifying the cause of the write concern error.
insert.writeConcernError.errmsg
A description of the cause of the write concern error.
The following is an example document returned for a successful insert (page 245) of a single document:
{ ok: 1, n: 1 }
The following is an example document returned for an insert (page 245) of two documents that successfully inserted
one document but encountered an error with the other document:
{
"ok" : 1,
"n" : 1,
"writeErrors" : [
{
"index" : 1,
"code" : 11000,
"errmsg" : "insertDocument :: caused by :: 11000 E11000 duplicate key error index: test.users.$_id_ dup key: { : 1.0 }"
}
]
}
parallelCollectionScan
parallelCollectionScan
New in version 2.6.
Allows applications to use multiple parallel cursors when reading all the documents from a collection, thereby
increasing throughput. The parallelCollectionScan (page 247) command returns a document that
contains an array of cursor information.
Each cursor provides access to the return of a partial set of documents from a collection. Iterating each cursor
returns every document in the collection. Cursors do not contain the results of the database command. The
result of the database command identies the cursors, but does not contain or constitute the cursors.
The server may return fewer cursors than requested.
The command has the following syntax:
{
parallelCollectionScan: "<collection>",
numCursors: <integer>
}
The parallelCollectionScan (page 247) command takes the following elds:
eld string parallelCollectionScan The name of the collection.
eld integer numCursors The maximum number of cursors to return. Must be between 1 and
10000, inclusive.
2.2. Database Commands 247
MongoDB Reference Manual, Release 2.6.4
Output The parallelCollectionScan (page 247) command returns a document containing the array of cur-
sor information:
{
"cursors" : [
{
"cursor" : {
"firstBatch" : [ ],
"ns" : "<database name>.<collection name>",
"id" : NumberLong("155949257847")
},
"ok" : true
}
],
"ok" : 1
}
parallelCollectionScan.cursors
An array with one or more cursors returned with the command.
parallelCollectionScan.cursors.cursor
For each cursor returned, a document with details about the cursor.
parallelCollectionScan.cursors.cursor.firstBatch
An empty rst batch is useful for quickly returning a cursor or failure message without doing signicant server-
side work. See cursor batches.
parallelCollectionScan.cursors.cursor.ns
The namespace for each cursor.
parallelCollectionScan.cursors.cursor.id
The unique id for each cursor.
parallelCollectionScan.cursors.ok
The status of each cursor returned with the command.
parallelCollectionScan.ok
A value of 1 indicates the parallelCollectionScan (page 247) command succeeded. A value of 0
indicates an error.
resetError
resetError
The resetError (page 248) command resets the last error status.
See also:
db.resetError() (page 124)
text
Denition
text
Deprecated since version 2.6: Use $text (page 401) query operator instead.
For document on the text (page 248), refer to the 2.4 Manual 2.4 Manual
19
.
19
http://docs.mongodb.org/v2.4/reference/command/text
248 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
update
Denition
update
New in version 2.6.
The update (page 249) command modies documents in a collection. A single update (page 249) com-
mand can contain multiple update statements. The update methods provided by the MongoDB drivers use this
command internally.
The update (page 249) command has the following syntax:
{
update: <collection>,
updates:
[
{ q: <query>, u: <update>, upsert: <boolean>, multi: <boolean> },
{ q: <query>, u: <update>, upsert: <boolean>, multi: <boolean> },
{ q: <query>, u: <update>, upsert: <boolean>, multi: <boolean> },
...
],
ordered: <boolean>,
writeConcern: { <write concern> }
}
The command takes the following elds:
eld string update The name of the target collection.
eld array updates An array of one or more update statements to perform in the named collection.
eld boolean ordered If true, then when an update statement fails, return without performing the
remaining update statements. If false, then when an update fails, continue with the remaining
update statements, if any. Defaults to true.
eld document writeConcern A document expressing the write concern of the update
(page 249) command. Omit to use the default write concern.
Each element of the updates array contains the following sub-elds:
eld string q The query that matches documents to update. Use the same query selectors (page 386)
as used in the find() (page 33) method.
eld document u The modications to apply. For details, see Behaviors (page 249).
eld boolean upsert If true, perform an insert if no documents match the query. If both upsert
and multi are true and no documents match the query, the update operation inserts only a
single document.
eld boolean multi If true, updates all documents that meet the query criteria. If false, limit
the update to one document that meet the query criteria. Defaults to false.
Returns A document that contains the status of the operation. See Output (page 251) for details.
Behaviors The <update> document can contain either all update operator (page 429) expressions or all
field:value expressions.
2.2. Database Commands 249
MongoDB Reference Manual, Release 2.6.4
Update Operator Expressions If the <update> document contains all update operator (page 429) expressions,
as in:
{
$set: { status: "D" },
$inc: { quantity: 2 }
}
Then, the update (page 249) command updates only the corresponding elds in the document.
Field: Value Expressions If the <update> document contains only field:value expressions, as in:
{
status: "D",
quantity: 4
}
Then the update (page 249) command replaces the matching document with the update document. The update
(page 249) command can only replace a single matching document; i.e. the multi eld cannot be true. The
update (page 249) command does not replace the _id value.
Limits For each update element in the updates array, the sum of the query and the update sizes (i.e. q and u )
must be less than or equal to the maximum BSON document size (page 658).
The total number of update statements in the updates array must be less than or equal to the maximum bulk
size.
Examples
Update Specic Fields of One Document Use update operators (page 429) to update only the specied elds of a
document.
For example, given a users collection, the following command uses the $set (page 436) and $inc (page 430) op-
erators to modify the status and the points elds respectively of a document where the user equals "abc123":
db.runCommand(
{
update: "users",
updates: [
{
q: { user: "abc123" }, u: { $set: { status: "A" }, $inc: { points: 1 } }
}
],
ordered: false,
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
Because <update> document does not specify the optional multi eld, the update only modies one document,
even if more than one document matches the q match condition.
The returned document shows that the command found and updated a single document. See Output (page 251) for
details.
{ "ok" : 1, "nModified" : 1, "n" : 1 }
250 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Update Specic Fields of Multiple Documents Use update operators (page 429) to update only the specied elds
of a document, and include the multi eld set to true in the update statement.
For example, given a users collection, the following command uses the $set (page 436) and $inc (page 430)
operators to modify the status and the points elds respectively of all documents in the collection:
db.runCommand(
{
update: "users",
updates: [
{ q: { }, u: { $set: { status: "A" }, $inc: { points: 1 } }, multi: true }
],
ordered: false,
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
The update modies all documents that match the query specied in the q eld, namely the empty query which
matches all documents in the collection.
The returned document shows that the command found and updated multiple documents. See Output (page 251) for
details.
{ "ok" : 1, "nModified" : 100, "n" : 100 }
Bulk Update The following example performs multiple update operations on the users collection:
db.runCommand(
{
update: "users",
updates: [
{ q: { status: "P" }, u: { $set: { status: "D" } }, multi: true },
{ q: { _id: 5 }, u: { _id: 5, name: "abc123", status: "A" }, upsert: true }
],
ordered: false,
writeConcern: { w: "majority", wtimeout: 5000 }
}
)
The returned document shows that the command modied 10 documents and inserted a document with the _id value
5. See Output (page 251) for details.
{
"ok" : 1,
"nModified" : 10,
"n" : 11,
"upserted" : [
{
"index" : 1,
"_id" : 5
}
]
}
Output The returned document contains a subset of the following elds:
update.ok
The status of the command.
2.2. Database Commands 251
MongoDB Reference Manual, Release 2.6.4
update.n
The number of documents selected for update. If the update operation results in no change to the document,
e.g. $set (page 436) expression updates the value to the current value, n (page 251) can be greater than
nModified (page 252).
update.nModified
The number of documents updated. If the update operation results in no change to the document, such as setting
the value of the eld to its current value, nModified (page 252) can be less than n (page 251).
update.upserted
An array of documents that contains information for each document inserted through the update with upsert:
true.
Each document contains the following information:
update.upserted.index
An integer that identies the update with upsert:true statement in the updates array, which uses a
zero-based index.
update.upserted._id
The _id value of the added document.
update.writeErrors
An array of documents that contains information regarding any error encountered during the update operation.
The writeErrors (page 252) array contains an error document for each update statement that errors.
Each error document contains the following elds:
update.writeErrors.index
An integer that identies the update statement in the updates array, which uses a zero-based index.
update.writeErrors.code
An integer value identifying the error.
update.writeErrors.errmsg
A description of the error.
update.writeConcernError
Document that describe error related to write concern and contains the eld:
update.writeConcernError.code
An integer value identifying the cause of the write concern error.
update.writeConcernError.errmsg
A description of the cause of the write concern error.
The following is an example document returned for a successful update (page 249) command that performed an
upsert:
{
"ok" : 1,
"nModified" : 0,
"n" : 1,
"upserted" : [
{
"index" : 0,
"_id" : ObjectId("52ccb2118908ccd753d65882")
}
]
}
252 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The following is an example document returned for a bulk update involving three update statements, where one update
statement was successful and two other update statements encountered errors:
{
"ok" : 1,
"nModified" : 1,
"n" : 1,
"writeErrors" : [
{
"index" : 1,
"code" : 16837,
"errmsg" : "The _id field cannot be changed from {_id: 1.0} to {_id: 5.0}."
},
{
"index" : 2,
"code" : 16837,
"errmsg" : "The _id field cannot be changed from {_id: 2.0} to {_id: 6.0}."
},
]
}
Query Plan Cache Commands
Query Plan Cache Commands
Name Description
planCacheClearFilters (page 253) Clears index lter(s) for a collection.
planCacheClear (page 255) Removes cached query plan(s) for a collection.
planCacheListFilters (page 256) Lists the index lters for a collection.
planCacheListPlans (page 257) Displays the cached query plans for the specied query shape.
planCacheListQueryShapes (page 258) Displays the query shapes for which cached query plans exist.
planCacheSetFilter (page 260) Sets an index lter for a collection.
planCacheClearFilters
Denition
planCacheClearFilters
New in version 2.6.
Removes index lters on a collection. Although index lters only exist for the duration of the server process and
do not persist after shutdown, you can also clear existing index lters with the planCacheClearFilters
(page 253) command.
Specify the query shape to remove a specic index lter. Omit the query shape to clear all index lters on a
collection.
The command has the following syntax:
db.runCommand(
{
planCacheClearFilters: <collection>,
query: <query pattern>,
sort: <sort specification>,
projection: <projection specification>
2.2. Database Commands 253
MongoDB Reference Manual, Release 2.6.4
}
)
The planCacheClearFilters (page 253) command has the following eld:
eld string planCacheClearFilters The name of the collection.
eld document query The query predicate associated with the lter to remove. If omitted, clears
all lters from the collection.
The values in the query predicate are insignicant in determining the query shape, so the
values used in the query need not match the values shown using planCacheListFilters
(page 256).
eld document sort The sort associated with the lter to remove, if any.
eld document projection The projection associated with the lter to remove, if any.
Required Access A user must have access that includes the planCacheIndexFilter action.
Examples
Clear Specic Index Filter on Collection The orders collection contains the following two lters:
{
"query" : { "status" : "A" },
"sort" : { "ord_date" : -1 },
"projection" : { },
"indexes" : [ { "status" : 1, "cust_id" : 1 } ]
}
{
"query" : { "status" : "A" },
"sort" : { },
"projection" : { },
"indexes" : [ { "status" : 1, "cust_id" : 1 } ]
}
The following command removes the second index lter only:
db.runCommand(
{
planCacheClearFilters: "orders",
query: { "status" : "A" }
}
)
Because the values in the query predicate are insignicant in determining the query shape, the following command
would also remove the second index lter:
db.runCommand(
{
planCacheClearFilters: "orders",
query: { "status" : "P" }
}
)
254 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Clear all Index Filters on a Collection The following example clears all index lters on the orders collection:
db.runCommand(
{
planCacheClearFilters: "orders"
}
)
See also:
planCacheListFilters (page 256), planCacheSetFilter (page 260)
planCacheClear
Denition
planCacheClear
New in version 2.6.
Removes cached query plans for a collection. Specify a query shape to remove cached query plans for that
shape. Omit the query shape to clear all cached query plans.
The command has the following syntax:
db.runCommand(
{
planCacheClear: <collection>,
query: <query>,
sort: <sort>,
projection: <projection>
}
)
The planCacheClear (page 255) command has the following eld:
eld document query The query predicate of the query shape. Only the structure of the predicate,
including the eld names, are signicant to the shape; the values in the query predicate are
insignicant.
eld document projection The projection associated with the query shape.
eld document sort The sort associated with the query shape.
To see the query shapes for which cached query plans exist, use the planCacheListQueryShapes
(page 258) command.
Required Access On systems running with authorization, a user must have access that includes the
planCacheWrite action.
Examples
Clear Cached Plans for a Query Shape If a collection orders has the following query shape:
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
}
2.2. Database Commands 255
MongoDB Reference Manual, Release 2.6.4
The following operation clears the query plan cached for the shape:
db.runCommand(
{
planCacheClear: "orders",
query: { "qty" : { "$gt" : 10 } },
sort: { "ord_date" : 1 }
}
)
Clear All Cached Plans for a Collection The following example clears all the cached query plans for the orders
collection:
db.runCommand(
{
planCacheClear: "orders"
}
)
See also:
PlanCache.clearPlansByQuery() (page 130)
PlanCache.clear() (page 130)
planCacheListFilters
Denition
planCacheListFilters
New in version 2.6.
Lists the index lters associated with query shapes for a collection.
The command has the following syntax:
db.runCommand( { planCacheListFilters: <collection> } )
The planCacheListFilters (page 256) command has the following eld:
eld string planCacheListFilters The name of the collection.
Returns Document listing the index lters. See Output (page 256).
Required Access A user must have access that includes the planCacheIndexFilter action.
Output The planCacheListFilters (page 256) command returns the document with the following form:
{
"filters" : [
{
"query" : <query>
"sort" : <sort>,
"projection" : <projection>,
"indexes" : [
<index1>,
...
256 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
]
},
...
],
"ok" : 1
}
planCacheListFilters.filters
The array of documents that contain the index lter information.
Each document contains the following elds:
planCacheListFilters.filters.query
The query predicate associated with this lter. Although the query (page 257) shows the specic values
used to create the index lter, the values in the predicate are insignicant; i.e. query predicates cover
similar queries that differ only in the values.
For instance, a query (page 257) predicate of { "type": "electronics", "status" :
"A" } covers the following query predicates:
{ type: "food", status: "A" }
{ type: "utensil", status: "D" }
Together with the sort (page 257) and the projection (page 257), the query (page 257) make up
the query shape for the specied index lter.
planCacheListFilters.filters.sort
The sort associated with this lter. Can be an empty document.
Together with the query (page 257) and the projection (page 257), the sort (page 257) make up
the query shape for the specied index lter.
planCacheListFilters.filters.projection
The projection associated with this lter. Can be an empty document.
Together with the query (page 257) and the sort (page 257), the projection (page 257) make up
the query shape for the specied index lter.
planCacheListFilters.filters.indexes
The array of indexes for this query shape. To choose the optimal query plan, the query optimizer evaluates
only the listed indexes and the collection scan.
planCacheListFilters.ok
The status of the command.
See also:
planCacheClearFilters (page 253), planCacheSetFilter (page 260)
planCacheListPlans
Denition
planCacheListPlans
New in version 2.6.
Displays the cached query plans for the specied query shape.
The query optimizer only caches the plans for those query shapes that can have more than one viable plan.
The mongo (page 580) shell provides the wrapper PlanCache.getPlansByQuery() (page 131) for this
command.
2.2. Database Commands 257
MongoDB Reference Manual, Release 2.6.4
The planCacheListPlans (page 257) command has the following syntax:
db.runCommand(
{
planCacheListPlans: <collection>,
query: <query>,
sort: <sort>,
projection: <projection>
}
The planCacheListPlans (page 257) command has the following eld:
eld document query The query predicate of the query shape. Only the structure of the predicate,
including the eld names, are signicant to the shape; the values in the query predicate are
insignicant.
eld document projection The projection associated with the query shape.
eld document sort The sort associated with the query shape.
To see the query shapes for which cached query plans exist, use the planCacheListQueryShapes
(page 258) command.
Required Access On systems running with authorization, a user must have access that includes the
planCacheRead action.
Example If a collection orders has the following query shape:
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
}
The following operation displays the query plan cached for the shape:
db.runCommand(
{
planCacheListPlans: "orders",
query: { "qty" : { "$gt" : 10 } },
sort: { "ord_date" : 1 }
}
)
See also:
planCacheListQueryShapes (page 258)
PlanCache.getPlansByQuery() (page 131)
PlanCache.listQueryShapes() (page 132)
planCacheListQueryShapes
Denition
planCacheListQueryShapes
New in version 2.6.
Displays the query shapes for which cached query plans exist for a collection.
258 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The query optimizer only caches the plans for those query shapes that can have more than one viable plan.
The mongo (page 580) shell provides the wrapper PlanCache.listQueryShapes() (page 132) for this
command.
The command has the following syntax:
db.runCommand(
{
planCacheListQueryShapes: <collection>
}
The planCacheListQueryShapes (page 258) command has the following eld:
eld string planCacheListQueryShapes The name of the collection.
Returns A document that contains an array of query shapes for which cached query plans exist.
Required Access On systems running with authorization, a user must have access that includes the
planCacheRead action.
Example The following returns the query shapes that have cached plans for the orders collection:
db.runCommand(
{
planCacheListQueryShapes: "orders"
}
)
The command returns a document that contains the eld shapes that contains an array of the query shapes currently
in the cache. In the example, the orders collection had cached query plans associated with the following shapes:
{
"shapes" : [
{
"query" : { "qty" : { "$gt" : 10 } },
"sort" : { "ord_date" : 1 },
"projection" : { }
},
{
"query" : { "$or" : [ { "qty" : { "$gt" : 15 } }, { "status" : "A" } ] },
"sort" : { },
"projection" : { }
},
{
"query" : { "$or" :
[
{ "qty" : { "$gt" : 15 }, "item" : "xyz123" },
{ "status" : "A" }
]
},
"sort" : { },
"projection" : { }
}
],
"ok" : 1
}
See also:
2.2. Database Commands 259
MongoDB Reference Manual, Release 2.6.4
PlanCache.listQueryShapes() (page 132)
planCacheSetFilter
Denition
planCacheSetFilter
New in version 2.6.
Set an index lter for a collection. If an index lter already exists for the query shape, the command overrides
the previous index lter.
The command has the following syntax:
db.runCommand(
{
planCacheSetFilter: <collection>,
query: <query>,
sort: <sort>,
projection: <projection>,
indexes: [ <index1>, <index2>, ...]
}
)
The planCacheSetFilter (page 260) command has the following eld:
eld string planCacheSetFilter The name of the collection.
eld document query The query predicate associated with the index lter. Together with the sort
and the projection, the query predicate make up the query shape for the specied index
lter.
Only the structure of the predicate, including the eld names, are signicant; the values in the
query predicate are insignicant. As such, query predicates cover similar queries that differ only
in the values.
eld document sort The sort associated with the lter. Together with the query and the
projection, the sort make up the query shape for the specied index lter.
eld document projection The projection associated with the lter. Together with the query and
the sort, the projection make up the query shape for the specied index lter.
eld array indexes An array of index specication documents that act as the index lter for the
specied query shape. Because the query optimizer chooses among the collection scan
and these indexes, if the indexes are non-existent, the optimizer will choose the collection scan.
Index lters only exist for the duration of the server process and do not persist after shutdown; however, you can
also clear existing index lters using the planCacheClearFilters (page 253) command.
Required Access A user must have access that includes the planCacheIndexFilter action.
Examples The following example creates an index lter on the orders collection such that for queries that consists
only of an equality match on the status eld without any projection and sort, the query optimizer evaluates only the
two specied indexes and the collection scan for the winning plan:
db.runCommand(
{
planCacheSetFilter: "orders",
query: { status: "A" },
260 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
indexes: [
{ cust_id: 1, status: 1 },
{ status: 1, order_date: -1 }
]
}
)
In the query predicate, only the structure of the predicate, including the eld names, are signicant; the values are
insignicant. As such, the created lter applies to the following operations:
db.orders.find( { status: "D" } )
db.orders.find( { status: "P" } )
To see whether MongoDB applied an index lter for a query, check the explain.filterSet (page 87) eld of
the explain() (page 83) output.
See also:
planCacheClearFilters (page 253), planCacheListFilters (page 256)
2.2.2 Database Operations
Authentication Commands
Authentication Commands
Name Description
authSchemaUpgrade
(page 261)
Supports the upgrade process for user data between version 2.4 and 2.6.
authenticate
(page 261)
Starts an authenticated session using a username and password.
copydbgetnonce
(page 262)
This is an internal command to generate a one-time password for use with the
copydb (page 319) command.
getnonce (page 262) This is an internal command to generate a one-time password for authentication.
logout (page 262) Terminates the current authenticated session.
authSchemaUpgrade New in version 2.6.
authSchemaUpgrade
authSchemaUpgrade (page 261) supports the upgrade from 2.4 to 2.6 process for existing systems that
use authentication and authorization. Between 2.4 and 2.6 the schema for user credential documents changed
requiring the authSchemaUpgrade (page 261) process.
See Upgrade User Authorization Data to 2.6 Format (page 706) for more information.
authenticate
authenticate
Clients use authenticate (page 261) to authenticate a connection. When using the shell, use the
db.auth() (page 102) helper as follows:
db.auth( "username", "password" )
See
2.2. Database Commands 261
MongoDB Reference Manual, Release 2.6.4
db.auth() (page 102) and http://docs.mongodb.org/manualcore/security for more infor-
mation.
copydbgetnonce
copydbgetnonce
Client libraries use copydbgetnonce (page 262) to get a one-time password for use with the copydb
(page 319) command.
Note: This command obtains a write lock on the affected database and will block other operations until it has
completed; however, the write lock for this operation is short lived.
getnonce
getnonce
Client libraries use getnonce (page 262) to generate a one-time password for authentication.
logout
logout
The logout (page 262) command terminates the current authenticated session:
{ logout: 1 }
Note: If youre not logged in and using authentication, logout (page 262) has no effect.
Changed in version 2.4: Because MongoDB now allows users dened in one database to have privileges on an-
other database, you must call logout (page 262) while using the same database context that you authenticated
to.
If you authenticated to a database such as users or $external, you must issue logout (page 262) against
this database in order to successfully log out.
Example
Use the use <database-name> helper in the interactive mongo (page 580) shell, or the following
db.getSiblingDB() (page 118) in the interactive shell or in mongo (page 580) shell scripts to change
the db object:
db = db.getSiblingDB('<database-name>')
When you have set the database context and db object, you can use the logout (page 262) to log out of
database as in the following operation:
db.runCommand( { logout: 1 } )
262 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
User Management Commands
User Management Commands
Name Description
createUser (page 263) Creates a new user.
dropAllUsersFromDatabase (page 264) Deletes all users associated with a database.
dropUser (page 265) Removes a single user.
grantRolesToUser (page 266) Grants a role and its privileges to a user.
revokeRolesFromUser (page 267) Removes a role from a user.
updateUser (page 268) Updates a users data.
usersInfo (page 270) Returns information about the specied users.
createUser
Denition
createUser
Creates a new user on the database where you run the command. The createUser (page 263) command
returns a duplicate user error if the user exists. The createUser (page 263) command uses the following
syntax:
{ createUser: "<name>",
pwd: "<cleartext password>",
customData: { <any information> },
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
createUser (page 263) has the following elds:
eld string createUser The name of the new user.
eld string pwd The users password. The pwd eld is not required if you run createUser
(page 263) on the $external database to create users who have credentials stored externally
to MongoDB.
any document customData Any arbitrary information. This eld can be used to store any data an
admin wishes to associate with this particular user. For example, this could be the users full
name or employee id.
eld array roles The roles granted to the user. Can specify an empty array [] to create users without
roles.
eld boolean digestPassword When true, the mongod (page 555) instance will create the hash
of the user password; otherwise, the client is responsible for creating the hash of the password.
Defaults to true.
eld document writeConcern The level of write concern for the creation operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
2.2. Database Commands 263
MongoDB Reference Manual, Release 2.6.4
To specify a role that exists in the same database where createUser (page 263) runs, you can either specify
the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Behavior createUser (page 263) sends password to the MongoDB instance in cleartext. To encrypt the password
in transit, use SSL.
Users created on the $external database should have credentials stored externally to MongoDB, as, for example,
with MongoDB Enterprise installations that use Kerberos.
Required Access You must have the createUser action on a database to create a new user on that database.
You must have the grantRole action on a roles database to grant the role to another user.
If you have the userAdmin or userAdminAnyDatabase role, you have those actions.
Example The following createUser (page 263) command creates a user accountAdmin01 on the products
database. The command gives accountAdmin01 the clusterAdmin and readAnyDatabase roles on the
admin database and the readWrite role on the products database:
db.getSiblingDB("products").runCommand( { createUser: "accountAdmin01",
pwd: "cleartext password",
customData: { employeeId: 12345 },
roles: [
{ role: "clusterAdmin", db: "admin" },
{ role: "readAnyDatabase", db: "admin" },
"readWrite"
],
writeConcern: { w: "majority" , wtimeout: 5000 }
} )
dropAllUsersFromDatabase
Denition
dropAllUsersFromDatabase
Removes all users from the database on which you run the command.
Warning: The dropAllUsersFromDatabase (page 264) removes all users from the database.
The dropAllUsersFromDatabase (page 264) command has the following syntax:
{ dropAllUsersFromDatabase: 1,
writeConcern: { <write concern> }
}
The dropAllUsersFromDatabase (page 264) document has the following elds:
eld integer dropAllUsersFromDatabase Specify 1 to drop all the users fromthe current database.
264 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Required Access You must have the dropUser action on a database to drop a user from that database.
Example The following sequence of operations in the mongo (page 580) shell drops every user fromthe products
database:
use products
db.runCommand( { dropAllUsersFromDatabase: 1, writeConcern: { w: "majority" } } )
The n eld in the results document shows the number of users removed:
{ "n" : 12, "ok" : 1 }
dropUser
Denition
dropUser
Removes the user from the database on which you run the command. The dropUser (page 265) command has
the following syntax:
{
dropUser: "<user>",
writeConcern: { <write concern> }
}
The dropUser (page 265) command document has the following elds:
eld string dropUser The name of the user to delete. You must issue the dropUser (page 265)
command while using the database where the user exists.
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Required Access You must have the dropUser action on a database to drop a user from that database.
Example The following sequence of operations in the mongo (page 580) shell removes accountAdmin01 from
the products database:
use products
db.runCommand( { dropUser: "accountAdmin01",
writeConcern: { w: "majority", wtimeout: 5000 }
} )
grantRolesToUser
2.2. Database Commands 265
MongoDB Reference Manual, Release 2.6.4
Denition
grantRolesToUser
Grants additional roles to a user.
The grantRolesToUser (page 266) command uses the following syntax:
{ grantRolesToUser: "<user>",
roles: [ <roles> ],
writeConcern: { <write concern> }
}
The command has the following elds:
eld string grantRolesToUser The name of the user to give additional roles.
eld array roles An array of additional roles to grant to the user.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where grantRolesToUser (page 266) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Required Access You must have the grantRole action on a database to grant a role on that database.
Example Given a user accountUser01 in the products database with the following roles:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]
The following grantRolesToUser (page 266) operation gives accountUser01 the read role on the stock
database and the readWrite role on the products database.
use products
db.runCommand( { grantRolesToUser: "accountUser01",
roles: [
{ role: "read", db: "stock"},
"readWrite"
],
writeConcern: { w: "majority" , wtimeout: 2000 }
} )
The user accountUser01 in the products database now has the following roles:
266 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]
revokeRolesFromUser
Denition
revokeRolesFromUser
Removes a one or more roles from a user on the database where the roles exist. The revokeRolesFromUser
(page 267) command uses the following syntax:
{ revokeRolesFromUser: "<user>",
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
The command has the following elds:
eld string revokeRolesFromUser The user to remove roles from.
eld array roles The roles to remove from the user.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where revokeRolesFromUser (page 267) runs, you can
either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Required Access You must have the revokeRole action on a database to revoke a role on that database.
Example The accountUser01 user in the products database has the following roles:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
2.2. Database Commands 267
MongoDB Reference Manual, Release 2.6.4
},
{ "role" : "read",
"db" : "stock"
},
{ "role" : "readWrite",
"db" : "products"
}
]
The following revokeRolesFromUser (page 267) command removes the two of the users roles: the read role
on the stock database and the readWrite role on the products database, which is also the database on which
the command runs:
use products
db.runCommand( { revokeRolesFromUser: "accountUser01",
roles: [
{ role: "read", db: "stock" },
"readWrite"
],
writeConcern: { w: "majority" }
} )
The user accountUser01 in the products database now has only one remaining role:
"roles" : [
{ "role" : "assetsReader",
"db" : "assets"
}
]
updateUser
Denition
updateUser
Updates the users prole on the database on which you run the command. An update to a eld completely
replaces the previous elds values, including updates to the users roles array.
Warning: When you update the roles array, you completely replace the previous arrays values. To add
or remove roles without replacing all the users existing roles, use the grantRolesToUser (page 266) or
revokeRolesFromUser (page 267) commands.
The updateUser (page 268) command uses the following syntax. To update a user, you must specify the
updateUser eld and at least one other eld, other than writeConcern:
{ updateUser: "<username>",
pwd: "<cleartext password>",
customData: { <any information> },
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
The command has the following elds:
268 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld string updateUser The name of the user to update.
eld string pwd The users password.
eld document customData Any arbitrary information.
eld array roles The roles granted to the user. An update to the roles array overrides the previous
arrays values.
eld boolean digestPassword When true, the mongod (page 555) instance will create the hash
of the user password; otherwise, the client is responsible for creating the hash of the password.
Defaults to true.
eld document writeConcern The level of write concern for the update operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where updateUser (page 268) runs, you can either specify
the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Behavior updateUser (page 268) sends the password to the MongoDB instance in cleartext. To encrypt the
password in transit, use SSL.
Required Access You must have access that includes the revokeRole action on all databases in order to update a
users roles array.
You must have the grantRole action on a roles database to add a role to a user.
To change another users pwd or customData eld, you must have the changeAnyPassword and
changeAnyCustomData actions respectively on that users database.
To modify your own password or custom data, you must have the changeOwnPassword and
changeOwnCustomData actions respectively on the cluster resource.
Example Given a user appClient01 in the products database with the following user info:
{
"_id" : "products.appClient01",
"user" : "appClient01",
"db" : "products",
"customData" : { "empID" : "12345", "badge" : "9156" },
"roles" : [
{ "role" : "readWrite",
"db" : "products"
},
{ "role" : "read",
"db" : "inventory"
}
]
}
2.2. Database Commands 269
MongoDB Reference Manual, Release 2.6.4
The following updateUser (page 268) command completely replaces the users customData and roles data:
use products
db.runCommand( { updateUser : "appClient01",
customData : { employeeId : "0x3039" },
roles : [
{ role : "read", db : "assets" }
]
} )
The user appClient01 in the products database now has the following user information:
{
"_id" : "products.appClient01",
"user" : "appClient01",
"db" : "products",
"customData" : { "employeeId" : "0x3039" },
"roles" : [
{ "role" : "read",
"db" : "assets"
}
]
}
usersInfo
Denition
usersInfo
Returns information about one or more users. To match a single user on the database, use the following form:
{ usersInfo: { user: <name>, db: <db> },
showCredentials: <Boolean>,
showPrivileges: <Boolean>
}
The command has the following elds:
eld various usersInfo The user(s) about whom to return information. See Behavior (page 270) for
type and syntax.
eld Boolean showCredentials Set the eld to true to display the users password hash. By default,
this eld is false.
eld Boolean showPrivileges Set the eld to true to show the users full set of privileges, including
expanded information for the inherited roles. By default, this eld is false. If viewing all
users, you cannot specify this eld.
Required Access Users can always view their own information.
To view another users information, the user running the command must have privileges that include the viewUser
action on the other users database.
Behavior The argument to the usersInfo (page 270) command has multiple forms depending on the requested
information:
270 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Specify a Single User In the usersInfo eld, specify a document with the users name and database:
{ usersInfo: { user: <name>, db: <db> } }
Alternatively, for a user that exists on the same database where the command runs, you can specify the user by its
name only.
{ usersInfo: <name> }
Specify Multiple Users In the usersInfo eld, specify an array of documents:
{ usersInfo: [ { user: <name>, db: <db> }, { user: <name>, db: <db> }, ... ] }
Specify All Users for a Database In the usersInfo eld, specify 1:
{ usersInfo: 1 }
Examples
View Specic Users To see information and privileges, but not the credentials, for the userKari dened in
"home" database, run the following command:
db.runCommand(
{
usersInfo: { user: "Kari", db: "home" },
showPrivileges: true
}
)
To view a user that exists in the current database, you can specify the user by name only. For example, if you are in
the home database and a user named "Kari" exists in the home database, you can run the following command:
db.getSiblingDB("home").runCommand(
{
usersInfo: "Kari",
showPrivileges: true
}
)
View Multiple Users To view info for several users, use an array, with or without the optional elds
showPrivileges and showCredentials. For example:
db.runCommand( { usersInfo: [ { user: "Kari", db: "home" }, { user: "Li", db: "myApp" } ],
showPrivileges: true
} )
View All Users for a Database To view all users on the database the command is run, use a command document
that resembles the following:
db.runCommand( { usersInfo: 1 } )
When viewing all users, you can specify the showCredentials eld but not the showPrivileges eld.
2.2. Database Commands 271
MongoDB Reference Manual, Release 2.6.4
Role Management Commands
Role Management Commands
Name Description
createRole (page 272) Creates a role and species its privileges.
dropAllRolesFromDatabase
(page 273)
Deletes all user-dened roles from a database.
dropRole (page 274) Deletes the user-dened role.
grantPrivilegesToRole
(page 275)
Assigns privileges to a user-dened role.
grantRolesToRole (page 276) Species roles from which a user-dened role inherits privileges.
invalidateUserCache (page 277) Flushes the in-memory cache of user information, including
credentials and roles.
revokePrivilegesFromRole
(page 277)
Removes the specied privileges from a user-dened role.
revokeRolesFromRole (page 280) Removes specied inherited roles from a user-dened role.
rolesInfo (page 281) Returns information for the specied role or roles.
updateRole (page 284) Updates a user-dened role.
createRole
Denition
createRole
Creates a role and species its privileges. The role applies to the database on which you run the command. The
createRole (page 272) command returns a duplicate role error if the role already exists in the database.
The createRole (page 272) command uses the following syntax:
{ createRole: "<new role>",
privileges: [
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: <write concern document>
}
The createRole (page 272) command has the following elds:
eld string createRole The name of the new role.
eld array privileges The privileges to grant the role. A privilege consists of a resource and per-
mitted actions. You must specify the privileges eld. Use an empty array to specify no
privileges. For the syntax of a privilege, see the privileges array.
eld array roles An array of roles from which this role inherits privileges. You must specify the
roles eld. Use an empty array to specify no roles.
eld document writeConcern The level of write concern to apply to this operation. The
writeConcern document uses the same elds as the getLastError (page 243) command.
In the roles eld, you can specify both built-in roles and user-dened role.
272 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
To specify a role that exists in the same database where createRole (page 272) runs, you can either specify
the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Behavior A roles privileges apply to the database where the role is created. The role can inherit privileges from
other roles in its database. A role created on the admin database can include privileges that apply to all databases or
to the cluster and can inherit privileges from roles in other databases.
Required Access You must have the createRole action on a database to create a role on that database.
You must have the grantRole action on the database that a privilege targets in order to grant that privilege to a role.
If the privilege targets multiple databases or the cluster resource , you must have the grantRole action on the
admin database.
You must have the grantRole action on a roles database to grant the role to another role.
Example The following createRole (page 272) command creates the myClusterwideAdmin role on the
admin database:
use admin
db.runCommand({ createRole: "myClusterwideAdmin",
privileges: [
{ resource: { cluster: true }, actions: [ "addShard" ] },
{ resource: { db: "config", collection: "" }, actions: [ "find", "update", "insert", "remove" ] },
{ resource: { db: "users", collection: "usersCollection" }, actions: [ "update", "insert", "remove" ] },
{ resource: { db: "", collection: "" }, actions: [ "find" ] }
],
roles: [
{ role: "read", db: "admin" }
],
writeConcern: { w: "majority" , wtimeout: 5000 }
})
dropAllRolesFromDatabase
Denition
dropAllRolesFromDatabase
Deletes all user-dened roles on the database where you run the command.
Warning: The dropAllRolesFromDatabase (page 273) removes all user-dened roles from the
database.
The dropAllRolesFromDatabase (page 273) command takes the following form:
{
dropAllRolesFromDatabase: 1,
writeConcern: { <write concern> }
}
2.2. Database Commands 273
MongoDB Reference Manual, Release 2.6.4
The command has the following elds:
eld integer dropAllRolesFromDatabase Specify 1 to drop all user-dened roles from the
database where the command is run.
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Required Access You must have the dropRole action on a database to drop a role from that database.
Example The following operations drop all user-dened roles from the products database:
use products
db.runCommand(
{
dropAllRolesFromDatabase: 1,
writeConcern: { w: "majority" }
}
)
The n eld in the results document reports the number of roles dropped:
{ "n" : 4, "ok" : 1 }
dropRole
Denition
dropRole
Deletes a user-dened role from the database on which you run the command.
The dropRole (page 274) command uses the following syntax:
{
dropRole: "<role>",
writeConcern: { <write concern> }
}
The dropRole (page 274) command has the following elds:
eld string dropRole The name of the user-dened role to remove from the database.
eld document writeConcern The level of write concern for the removal operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Required Access You must have the dropRole action on a database to drop a role from that database.
Example The following operations remove the readPrices role from the products database:
use products
db.runCommand(
{
dropRole: "readPrices",
writeConcern: { w: "majority" }
274 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
}
)
grantPrivilegesToRole
Denition
grantPrivilegesToRole
Assigns additional privileges to a user-dened role dened on the database on which the command is run. The
grantPrivilegesToRole (page 275) command uses the following syntax:
{
grantPrivilegesToRole: "<role>",
privileges: [
{
resource: { <resource> }, actions: [ "<action>", ... ]
},
...
],
writeConcern: { <write concern> }
}
The grantPrivilegesToRole (page 275) command has the following elds:
eld string grantPrivilegesToRole The name of the user-dened role to grant privileges to.
eld array privileges The privileges to add to the role. For the format of a privilege, see
privileges.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Behavior A roles privileges apply to the database where the role is created. A role created on the admin database
can include privileges that apply to all databases or to the cluster.
Required Access You must have the grantRole action on the database a privilege targets in order to grant the
privilege. To grant a privilege on multiple databases or on the cluster resource, you must have the grantRole
action on the admin database.
Example The following grantPrivilegesToRole (page 275) command grants two additional privileges to the
service role that exists in the products database:
use products
db.runCommand(
{
grantPrivilegesToRole: "service",
privileges: [
{
resource: { db: "products", collection: "" }, actions: [ "find" ]
},
{
resource: { db: "products", collection: "system.indexes" }, actions: [ "find" ]
}
],
2.2. Database Commands 275
MongoDB Reference Manual, Release 2.6.4
writeConcern: { w: "majority" , wtimeout: 5000 }
}
)
The rst privilege in the privileges array allows the user to search on all non-system collections in the products
database. The privilege does not allow searches on system collections (page 654), such as the system.indexes
(page 655) collection. To grant access to these system collections, explicitly provision access in the privileges
array. See http://docs.mongodb.org/manualreference/resource-document.
The second privilege explicitly allows the find action on system.indexes (page 655) collections on all
databases.
grantRolesToRole
Denition
grantRolesToRole
Grants roles to a user-dened role.
The grantRolesToRole (page 276) command affects roles on the database where the command runs.
grantRolesToRole (page 276) has the following syntax:
{ grantRolesToRole: "<role>",
roles: [
{ role: "<role>", db: "<database>" },
...
],
writeConcern: { <write concern> }
}
The grantRolesToRole (page 276) command has the following elds:
eld string grantRolesToRole The name of a role to add subsidiary roles.
eld array roles An array of roles from which to inherit.
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where grantRolesToRole (page 276) runs, you can either
specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Behavior A role can inherit privileges from other roles in its database. A role created on the admin database can
inherit privileges from roles in any database.
Required Access You must have the grantRole action on a database to grant a role on that database.
276 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example The following grantRolesToRole (page 276) command updates the productsReaderWriter
role in the products database to inherit the privileges of the productsReader role in the products database:
use products
db.runCommand(
{ grantRolesToRole: "productsReaderWriter",
roles: [
"productsReader"
],
writeConcern: { w: "majority" , wtimeout: 5000 }
}
)
invalidateUserCache
Denition
invalidateUserCache
New in version 2.6.
Flushes user information from in-memory cache, including removal of each users credentials and
roles. This allows you to purge the cache at any given moment, regardless of the interval set in the
userCacheInvalidationIntervalSecs parameter.
invalidateUserCache (page 277) has the following syntax:
db.runCommand( { invalidateUserCache: 1 } )
Required Access You must have privileges that include the invalidateUserCache action on the cluster re-
source in order to use this command.
revokePrivilegesFromRole
Denition
revokePrivilegesFromRole
Removes the specied privileges from the user-dened role on the database where the command is run. The
revokePrivilegesFromRole (page 277) command has the following syntax:
{
revokePrivilegesFromRole: "<role>",
privileges:
[
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
writeConcern: <write concern document>
}
The revokePrivilegesFromRole (page 277) command has the following elds:
eld string revokePrivilegesFromRole The user-dened role to revoke privileges from.
eld array privileges An array of privileges to remove from the role. See privileges for more
information on the format of the privileges.
2.2. Database Commands 277
MongoDB Reference Manual, Release 2.6.4
eld document writeConcern The level of write concern for the modication. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
Behavior To revoke a privilege, the resource document pattern must match exactly the resource eld of
that privilege. The actions eld can be a subset or match exactly.
For example, consider the role accountRole in the products database with the following privilege that species
the products database as the resource:
{
"resource" : {
"db" : "products",
"collection" : ""
},
"actions" : [
"find",
"update"
]
}
You cannot revoke find and/or update from just one collection in the products database. The following opera-
tions result in no change to the role:
use products
db.runCommand(
{
revokePrivilegesFromRole: "accountRole",
privileges:
[
{
resource : {
db : "products",
collection : "gadgets"
},
actions : [
"find",
"update"
]
}
]
}
)
db.runCommand(
{
revokePrivilegesFromRole: "accountRole",
privileges:
[
{
resource : {
db : "products",
collection : "gadgets"
},
actions : [
"find"
]
}
278 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
]
}
)
To revoke the "find" and/or the "update" action from the role accountRole, you must match the resource
document exactly. For example, the following operation revokes just the "find" action from the existing privilege.
use products
db.runCommand(
{
revokePrivilegesFromRole: "accountRole",
privileges:
[
{
resource : {
db : "products",
collection : ""
},
actions : [
"find"
]
}
]
}
)
Required Access You must have the revokeRole action on the database a privilege targets in order to revoke
that privilege. If the privilege targets multiple databases or the cluster resource, you must have the revokeRole
action on the admin database.
Example The following operation removes multiple privileges from the associates role in the products
database:
use products
db.runCommand(
{
revokePrivilegesFromRole: "associate",
privileges:
[
{
resource: { db: "products", collection: "" },
actions: [ "createCollection", "createIndex", "find" ]
},
{
resource: { db: "products", collection: "orders" },
actions: [ "insert" ]
}
],
writeConcern: { w: "majority" }
}
)
revokeRolesFromRole
2.2. Database Commands 279
MongoDB Reference Manual, Release 2.6.4
Denition
revokeRolesFromRole
Removes the specied inherited roles from a role. The revokeRolesFromRole (page 280) command has
the following syntax:
{ revokeRolesFromRole: "<role>",
roles: [
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: { <write concern> }
}
The command has the following elds:
eld string revokeRolesFromRole The role from which to remove inherited roles.
eld array roles The inherited roles to remove.
eld document writeConcern The level of write concern to apply to this operation. The
writeConcern document uses the same elds as the getLastError (page 243) command.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where revokeRolesFromRole (page 280) runs, you can
either specify the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Required Access You must have the revokeRole action on a database to revoke a role on that database.
Example The purchaseAgents role in the emea database inherits privileges from several other roles, as listed
in the roles array:
{
"_id" : "emea.purchaseAgents",
"role" : "purchaseAgents",
"db" : "emea",
"privileges" : [],
"roles" : [
{
"role" : "readOrdersCollection",
"db" : "emea"
},
{
"role" : "readAccountsCollection",
"db" : "emea"
},
{
"role" : "writeOrdersCollection",
"db" : "emea"
}
]
}
280 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The following revokeRolesFromRole (page 280) operation on the emea database removes two roles from the
purchaseAgents role:
use emea
db.runCommand( { revokeRolesFromRole: "purchaseAgents",
roles: [
"writeOrdersCollection",
"readOrdersCollection"
],
writeConcern: { w: "majority" , wtimeout: 5000 }
} )
The purchaseAgents role now contains just one role:
{
"_id" : "emea.purchaseAgents",
"role" : "purchaseAgents",
"db" : "emea",
"privileges" : [],
"roles" : [
{
"role" : "readAccountsCollection",
"db" : "emea"
}
]
}
rolesInfo
Denition
rolesInfo
Returns inheritance and privilege information for specied roles, including both user-dened roles and built-in
roles.
The rolesInfo (page 281) command can also retrieve all roles scoped to a database.
The command has the following elds:
eld string,document,array,integer rolesInfo The role(s) to return information about. For the syn-
tax for specifying roles, see Behavior (page 281).
eld Boolean showPrivileges Set the eld to true to show role privileges, including both privi-
leges inherited from other roles and privileges dened directly. By default, the command returns
only the roles from which this role inherits privileges and does not return specic privileges.
eld Boolean showBuiltinRoles When the rolesInfo eld is set to 1, set
showBuiltinRoles to true to include built-in roles in the output. By default this
eld is set to false, and the output for rolesInfo: 1 displays only user-dened roles.
Behavior When specifying roles, use the syntax described here.
To specify a role from the current database, specify the role by its name:
rolesInfo: "<rolename>"
To specify a role from another database, specify the role by a document that species the role and database:
2.2. Database Commands 281
MongoDB Reference Manual, Release 2.6.4
rolesInfo: { role: "<rolename>", db: "<database>" }
To specify multiple roles, use an array. Specify each role in the array as a document or string. Use a string only if the
role exists on the database on which the command runs:
rolesInfo:
[
"<rolename>",
{ role: "<rolename>", db: "<database>" },
...
]
To specify all roles in the database on which the command runs, specify rolesInfo: 1. By default MongoDB
displays all the user-dened roles in the database. To include built-in roles as well, include the parameter-value pair
showBuiltinRoles: true:
rolesInfo: 1, showBuiltinRoles: true
Required Access To view a roles information, you must be explicitly granted the role or must have the viewRole
action on the roles database.
Output
rolesInfo.role
The name of the role.
rolesInfo.db
The database on which the role is dened. Every database has built-in roles. A database might also have
user-dened roles.
rolesInfo.roles
The roles that directly provide privileges to this role and the databases on which the roles are dened.
rolesInfo.indirectRoles
All roles from which this role inherits privileges. This includes the roles in the rolesInfo.roles (page 282)
array as well as the roles from which the roles in the rolesInfo.roles (page 282) array inherit privileges.
All privileges apply to the current role. The documents in this eld list the roles and the databases on which
they are dened.
rolesInfo.privileges
All the privileges granted by this role. By default the output does not include this array. To include it, specify
showPrivileges: true when running the rolesInfo (page 281) command.
The array includes privileges dened directly in the role as well as privileges inherited from other roles.
Each set of privileges in the array is contained in its own document. Each document species the resources the
privilege accesses and the actions allowed.
rolesInfo.isBuiltin
A value of true indicates the role is a built-in role. A value of false indicates the role is a user-dened role.
Examples
View Information for a Single Role The following command returns the role inheritance information for the role
associate dened in the products database:
282 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.runCommand(
{
rolesInfo: { role: "associate", db: "products" }
}
)
The following command returns the role inheritance information for the role siteManager on the database on which
the command runs:
db.runCommand(
{
rolesInfo: "siteManager"
}
)
The following command returns both the role inheritance and the privileges for the role associate dened on the
products database:
db.runCommand(
{
rolesInfo:
{ role: "associate", db: "products" },
showPrivileges: true
}
)
View Information for Several Roles The following command returns information for two roles on two different
databases:
db.runCommand(
{
rolesInfo:
[
{ role: "associate", db: "products" },
{ role: "manager", db: "resources" },
]
}
)
The following returns both the role inheritance and the privileges:
db.runCommand(
{
rolesInfo:
[
{ role: "associate", db: "products" },
{ role: "manager", db: "resources" },
],
showPrivileges: true
}
)
View All User-Dened Roles for a Database The following operation returns all user-dened roles on the database
on which the command runs and includes privileges:
db.runCommand(
{
2.2. Database Commands 283
MongoDB Reference Manual, Release 2.6.4
rolesInfo: 1,
showPrivileges: true
}
)
View All User-Dened and Built-In Roles for a Database The following operation returns all roles on the database
on which the command runs, including both built-in and user-dened roles:
db.runCommand(
{
rolesInfo: 1,
showBuiltinRoles: true
}
)
updateRole
Denition
updateRole
Updates a user-dened role. The updateRole (page 284) command must run on the roles database.
An update to a eld completely replaces the previous elds values. To grant or remove roles or privileges
without replacing all values, use one or more of the following commands:
grantRolesToRole (page 276)
grantPrivilegesToRole (page 275)
revokeRolesFromRole (page 280)
revokePrivilegesFromRole (page 277)
Warning: An update to the privileges or roles array completely replaces the previous arrays values.
The updateRole (page 284) command uses the following syntax. To update a role, you must provide the
privileges array, roles array, or both:
{
updateRole: "<role>",
privileges:
[
{ resource: { <resource> }, actions: [ "<action>", ... ] },
...
],
roles:
[
{ role: "<role>", db: "<database>" } | "<role>",
...
],
writeConcern: <write concern document>
}
The updateRole (page 284) command has the following elds:
eld string updateRole The name of the user-dened role role to update.
284 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld array privileges Required if you do not specify roles array. The privileges to grant the role.
An update to the privileges array overrides the previous arrays values. For the syntax for
specifying a privilege, see the privileges array.
eld array roles Required if you do not specify privileges array. The roles from which this
role inherits privileges. An update to the roles array overrides the previous arrays values.
eld document writeConcern The level of write concern for the update operation. The
writeConcern document takes the same elds as the getLastError (page 243) com-
mand.
In the roles eld, you can specify both built-in roles and user-dened role.
To specify a role that exists in the same database where updateRole (page 284) runs, you can either specify
the role with the name of the role:
"readWrite"
Or you can specify the role with a document, as in:
{ role: "<role>", db: "<database>" }
To specify a role that exists in a different database, specify the role with a document.
Behavior A roles privileges apply to the database where the role is created. The role can inherit privileges from
other roles in its database. A role created on the admin database can include privileges that apply to all databases or
to the cluster and can inherit privileges from roles in other databases.
Required Access You must have the revokeRole action on all databases in order to update a role.
You must have the grantRole action on the database of each role in the roles array to update the array.
You must have the grantRole action on the database of each privilege in the privileges array to update the
array. If a privileges resource spans databases, you must have grantRole on the admin database. A privilege
spans databases if the privilege is any of the following:
a collection in all databases
all collections and all database
the cluster resource
Example The following is an example of the updateRole (page 284) command that updates the
myClusterwideAdmin role on the admin database. While the privileges and the roles arrays are both
optional, at least one of the two is required:
use admin
db.runCommand(
{
updateRole: "myClusterwideAdmin",
privileges:
[
{
resource: { db: "", collection: "" },
actions: [ "find" , "update", "insert", "remove" ]
}
],
roles:
[
2.2. Database Commands 285
MongoDB Reference Manual, Release 2.6.4
{ role: "dbAdminAnyDatabase", db: "admin" }
],
writeConcern: { w: "majority" }
}
)
To view a roles privileges, use the rolesInfo (page 281) command.
Replication Commands
Replication Commands
Name Description
applyOps (page 286) Internal command that applies oplog entries to the current data set.
getoptime (page 287) Internal command to support replication, returns the optime.
isMaster (page 287) Displays information about this members role in the replica set, including
whether it is the master.
replSetFreeze (page 289) Prevents the current member from seeking election as primary for a period of
time.
replSetGetStatus
(page 289)
Returns a document that reports on the status of the replica set.
replSetInitiate
(page 292)
Initializes a new replica set.
replSetMaintenance
(page 293)
Enables or disables a maintenance mode, which puts a secondary node in a
RECOVERING state.
replSetReconfig
(page 294)
Applies a new conguration to an existing replica set.
replSetStepDown
(page 294)
Forces the current primary to step down and become a secondary, forcing an
election.
replSetSyncFrom
(page 295)
Explicitly override the default logic for selecting a member to replicate from.
resync (page 295) Forces a mongod (page 555) to re-synchronize from the master. For
master-slave replication only.
applyOps
Denition
applyOps
Applies specied oplog entries to a mongod (page 555) instance. The applyOps (page 286) command is
primarily an internal command to support sharded clusters.
If authorization is enabled, you must have access to all actions on all resources in order to run applyOps
(page 286). Providing such access is not recommended, but if your organization requires a user to run
applyOps (page 286), create a role that grants anyAction on resource-anyresource. Do not assign this
role to any other user.
The applyOps (page 286) command has the following prototype form:
db.runCommand( { applyOps: [ <operations> ],
preCondition: [ { ns: <namespace>, q: <query>, res: <result> } ] } )
The applyOps (page 286) command takes a document with the following elds:
eld array applyOps The oplog entries to apply.
286 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld array preCondition An array of documents that contain the conditions that must be true in
order to apply the oplog entry. Each document contains a set of conditions, as described in the
next table.
The preCondition array takes one or more documents with the following elds:
eld string ns A namespace. If you use this eld, applyOps (page 286) applies oplog entries only
for the collection described by this namespace.
param string q Species the query that produces the results specied in the res eld.
param string res The results of the query in the q eld that must match to apply the oplog entry.
Behavior Warning: This command obtains a global write lock and will block other operations until it has completed.
getoptime
getoptime
getoptime (page 287) is an internal command.
isMaster
Denition
isMaster
isMaster (page 287) returns a document that describes the role of the mongod (page 555) instance.
If the instance is a member of a replica set, then isMaster (page 287) returns a subset of the replica set
conguration and status including whether or not the instance is the primary of the replica set.
When sent to a mongod (page 555) instance that is not a member of a replica set, isMaster (page 287) returns
a subset of this information.
MongoDB drivers and clients use isMaster (page 287) to determine the state of the replica set members and
to discover additional members of a replica set.
The db.isMaster() (page 120) method in the mongo (page 580) shell provides a wrapper around
isMaster (page 287).
The command takes the following form:
{ isMaster: 1 }
See also:
db.isMaster() (page 120)
Output
All Instances The following isMaster (page 287) elds are common across all roles:
isMaster.ismaster
A boolean value that reports when this node is writable. If true, then this instance is a primary in a replica
set, or a master in a master-slave conguration, or a mongos (page 571) instance, or a standalone mongod
(page 555).
This eld will be false if the instance is a secondary member of a replica set or if the member is an arbiter of
a replica set.
2.2. Database Commands 287
MongoDB Reference Manual, Release 2.6.4
isMaster.maxBsonObjectSize
The maximum permitted size of a BSON object in bytes for this mongod (page 555) process. If not provided,
clients should assume a max size of 16
*
1024
*
1024.
isMaster.maxMessageSizeBytes
New in version 2.4.
The maximum permitted size of a BSON wire protocol message. The default value is 48000000 bytes.
isMaster.localTime
New in version 2.2.
Returns the local server time in UTC. This value is an ISO date.
isMaster.minWireVersion
New in version 2.6.
The earliest version of the wire protocol that this mongod (page 555) or mongos (page 571) instance is capable
of using to communicate with clients.
Clients may use minWireVersion (page 288) to help negotiate compatibility with MongoDB.
isMaster.maxWireVersion
New in version 2.6.
The latest version of the wire protocol that this mongod (page 555) or mongos (page 571) instance is capable
of using to communicate with clients.
Clients may use maxWireVersion (page 288) to help negotiate compatibility with MongoDB.
Sharded Instances mongos (page 571) instances add the following eld to the isMaster (page 287) response
document:
isMaster.msg
Contains the value isdbgrid when isMaster (page 287) returns from a mongos (page 571) instance.
Replica Sets isMaster (page 287) contains these elds when returned by a member of a replica set:
isMaster.setName
The name of the current :replica set.
isMaster.secondary
A boolean value that, when true, indicates if the mongod (page 555) is a secondary member of a replica set.
isMaster.hosts
An array of strings in the format of "[hostname]:[port]" that lists all members of the replica set that are
neither hidden, passive, nor arbiters.
Drivers use this array and the isMaster.passives (page 288) to determine which members to read from.
isMaster.passives
An array of strings in the format of "[hostname]:[port]" listing all members of the replica set which
have a priority of 0.
This eld only appears if there is at least one member with a priority of 0.
Drivers use this array and the isMaster.hosts (page 288) to determine which members to read from.
isMaster.arbiters
An array of strings in the format of "[hostname]:[port]" listing all members of the replica set that are
arbiters.
This eld only appears if there is at least one arbiter in the replica set.
288 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
isMaster.primary
A string in the format of "[hostname]:[port]" listing the current primary member of the replica set.
isMaster.arbiterOnly
A boolean value that , when true, indicates that the current instance is an arbiter. The arbiterOnly
(page 289) eld is only present, if the instance is an arbiter.
isMaster.passive
A boolean value that, when true, indicates that the current instance is passive. The passive (page 289) eld
is only present for members with a priority of 0.
isMaster.hidden
A boolean value that, when true, indicates that the current instance is hidden. The hidden (page 289) eld
is only present for hidden members.
isMaster.tags
A document that lists any tags assigned to this member. This eld
is only present if there are tags assigned to the member. See
http://docs.mongodb.org/manualtutorial/configure-replica-set-tag-sets for
more information.
isMaster.me
The [hostname]:[port] of the member that returned isMaster (page 287).
replSetFreeze
replSetFreeze
The replSetFreeze (page 289) command prevents a replica set member from seeking election for the speci-
ed number of seconds. Use this command in conjunction with the replSetStepDown (page 294) command
to make a different node in the replica set a primary.
The replSetFreeze (page 289) command uses the following syntax:
{ replSetFreeze: <seconds> }
If you want to unfreeze a replica set member before the specied number of seconds has elapsed, you can issue
the command with a seconds value of 0:
{ replSetFreeze: 0 }
Restarting the mongod (page 555) process also unfreezes a replica set member.
replSetFreeze (page 289) is an administrative command, and you must issue it against the admin database.
replSetGetStatus
Denition
replSetGetStatus
The replSetGetStatus command returns the status of the replica set from the point of view of the current
server. You must run the command against the admin database. The command has the following prototype
format:
{ replSetGetStatus: 1 }
The value specied does not affect the output of the command. Data provided by this command derives from
data included in heartbeats sent to the current instance by other members of the replica set. Because of the
frequency of heartbeats, these data can be several seconds out of date.
2.2. Database Commands 289
MongoDB Reference Manual, Release 2.6.4
You can also access this functionality through the rs.status() (page 177) helper in the mongo (page 580)
shell.
The mongod (page 555) must have replication enabled and be a member of a replica set for the for
replSetGetStatus (page 289) to return successfully.
Example The following example runs the replSetGetStatus command on the admin database of the replica set
primary:
use admin
db.runCommand( { replSetGetStatus : 1 } )
Consider the following example output:
{
"set" : "replset",
"date" : ISODate("2014-05-01T14:44:03Z"),
"myState" : 1,
"members" : [
{
"_id" : 0,
"name" : "m1.example.net:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 269,
"optime" : Timestamp(1404225575, 11),
"optimeDate" : ISODate("2014-05-01T14:39:35Z"),
"electionTime" : Timestamp(1404225586, 1),
"electionDate" : ISODate("2014-05-01T14:39:46Z"),
"self" : true
},
{
"_id" : 1,
"name" : "m2.example.net:27017",
"health" : 1,
"state" : 2,
"stateStr" : "SECONDARY",
"uptime" : 265,
"optime" : Timestamp(1404225575, 11),
"optimeDate" : ISODate("2014-05-01T14:39:35Z"),
"lastHeartbeat" : ISODate("2014-05-01T14:44:03Z"),
"lastHeartbeatRecv" : ISODate("2014-05-01T14:44:02Z"),
"pingMs" : 0,
"syncingTo" : "m1.example.net:27017"
},
{
"_id" : 2,
"name" : "m3.example.net:27017",
"health" : 1,
"state" : 2,
"stateStr" : "SECONDARY",
"uptime" : 265,
"optime" : Timestamp(1404225575, 11),
"optimeDate" : ISODate("2014-05-01T14:39:35Z"),
"lastHeartbeat" : ISODate("2014-05-01T14:44:02Z"),
"lastHeartbeatRecv" : ISODate("2014-05-01T14:44:02Z"),
"pingMs" : 0,
290 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"syncingTo" : "m1.example.net:27017"
}
],
"ok" : 1
}
Output The replSetGetStatus command returns a document with the following elds:
replSetGetStatus.set
The set value is the name of the replica set, congured in the replSetName setting. This is the same value
as _id in rs.conf() (page 173).
replSetGetStatus.date
The value of the date eld is an ISODate of the current time, according to the current server. Compare this to
the value of the lastHeartbeat (page 292) to nd the operational lag between the current host and the other
hosts in the set.
replSetGetStatus.myState
The value of myState (page 291) is an integer between 0 and 10 that represents the replica state of the
current member.
replSetGetStatus.members
The members eld holds an array that contains a document for every member in the replica set.
replSetGetStatus.members.name
The name eld holds the name of the server.
replSetGetStatus.members.self
The self eld is only included in the document for the current mongod instance in the members array.
Its value is true.
replSetGetStatus.members.health
The health value is only present for the other members of the replica set (i.e. not the member that returns
rs.status (page 177).) This eld conveys if the member is up (i.e. 1) or down (i.e. 0.)
replSetGetStatus.members.state
The value of state (page 291) is an integer between 0 and 10 that represents the replica state of
the member.
replSetGetStatus.members.stateStr
A string that describes state (page 291).
replSetGetStatus.members.uptime
The uptime (page 291) eld holds a value that reects the number of seconds that this member has been
online.
This value does not appear for the member that returns the rs.status() (page 177) data.
replSetGetStatus.members.optime
Information regarding the last operation from the operation log that this member has applied.
replSetGetStatus.members.optime.t
A 32-bit timestamp of the last operation applied to this member of the replica set from the oplog.
replSetGetStatus.members.optime.i
An incremented eld, which reects the number of operations in since the last time stamp. This value
only increases if there is more than one operation per second.
replSetGetStatus.members.optimeDate
An ISODate formatted date string that reects the last entry from the oplog that this member applied. If this
2.2. Database Commands 291
MongoDB Reference Manual, Release 2.6.4
differs signicantly from lastHeartbeat (page 292) this member is either experiencing replication
lag or there have not been any new operations since the last update. Compare members.optimeDate
between all of the members of the set.
replSetGetStatus.members.electionTime
For the current primary, information regarding the election time from the operation log. See
http://docs.mongodb.org/manualcore/replica-set-elections for more information
about elections.
replSetGetStatus.members.electionTime.t
For the current primary, a 32-bit timestamp of the election time applied to this member of the replica
set from the oplog.
replSetGetStatus.members.electionTime.i
For the current primary, an incremented eld which reects the number of operations in since the last
time stamp. This value only increases if there is more than one operation per second.
replSetGetStatus.members.electionDate
For the current primary, an ISODate formatted date string that reects the election date. See
http://docs.mongodb.org/manualcore/replica-set-elections for more information
about elections.
replSetGetStatus.members.self
Indicates which replica set member processed the replSetGetStatus command.
replSetGetStatus.members.lastHeartbeat
The lastHeartbeat value provides an ISODate formatted date and time of the transmission time of
last heartbeat received from this member. Compare this value to the value of the date (page 291) and
lastHeartBeatRecv eld to track latency between these members.
This value does not appear for the member that returns the rs.status() (page 177) data.
replSetGetStatus.members.lastHeartbeatRecv
The lastHeartbeatRecv value provides an ISODate formatted date and time that the last heart-
beat was received from this member. Compare this value to the value of the date (page 291) and
lastHeartBeat eld to track latency between these members.
replSetGetStatus.members.lastHeartbeatMessage
When the last heartbeat included an extra message, the lastHeartbeatMessage (page 292) contains
a string representation of that message.
replSetGetStatus.members.pingMs
The pingMs represents the number of milliseconds (ms) that a round-trip packet takes to travel between
the remote member and the local instance.
This value does not appear for the member that returns the rs.status() (page 177) data.
replSetGetStatus.syncingTo
The syncingTo eld is only present on the output of rs.status() (page 177) on secondary and recovering
members, and holds the hostname of the member from which this instance is syncing.
replSetInitiate
replSetInitiate
The replSetInitiate (page 292) command initializes a new replica set. Use the following syntax:
{ replSetInitiate : <config_document> }
The <config_document> is a document that species the replica sets conguration. For instance, heres a
cong document for creating a simple 3-member replica set:
292 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
_id : <setname>,
members : [
{_id : 0, host : <host0>},
{_id : 1, host : <host1>},
{_id : 2, host : <host2>},
]
}
A typical way of running this command is to assign the cong document to a variable and then to pass the
document to the rs.initiate() (page 173) helper:
config = {
_id : "my_replica_set",
members : [
{_id : 0, host : "rs1.example.net:27017"},
{_id : 1, host : "rs2.example.net:27017"},
{_id : 2, host : "rs3.example.net", arbiterOnly: true},
]
}
rs.initiate(config)
Notice that omitting the port cause the host to use the default port of 27017. Notice also that you can specify
other options in the cong documents such as the arbiterOnly setting in this example.
See also:
http://docs.mongodb.org/manualreference/replica-configuration,
http://docs.mongodb.org/manualadministration/replica-sets, and Replica Set Re-
conguration (page 175).
replSetMaintenance
Denition
replSetMaintenance
The replSetMaintenance (page 293) admin command enables or disables the maintenance mode for a
secondary member of a replica set.
The command has the following prototype form:
{ replSetMaintenance: <boolean> }
Behavior Consider the following behavior when running the replSetMaintenance (page 293) command:
You cannot run the command on the Primary.
You must run the command against the admin database.
When enabled replSetMaintenance: true, the member enters the RECOVERING state. While the
secondary is RECOVERING:
The member is not accessible for read operations.
The member continues to sync its oplog from the Primary.
On secondaries, the compact (page 316) command forces the secondary to enter RECOVERING state. Read
operations issued to an instance in the RECOVERING state will fail. This prevents clients from reading during
the operation. When the operation completes, the secondary returns to:replstate:SECONDARY state.
2.2. Database Commands 293
MongoDB Reference Manual, Release 2.6.4
See http://docs.mongodb.org/manualreference/replica-states/ for more information
about replica set member states.
See http://docs.mongodb.org/manualtutorial/perform-maintence-on-replica-set-members
for an example replica set maintenance procedure to maximize availability during maintenance operations.
replSetRecong
replSetReconfig
The replSetReconfig (page 294) command modies the conguration of an existing replica set. You can
use this command to add and remove members, and to alter the options set on existing members. Use the
following syntax:
{ replSetReconfig: <new_config_document>, force: false }
You may also run replSetReconfig (page 294) with the shells rs.reconfig() (page 175) method.
Behaviors Be aware of the following replSetReconfig (page 294) behaviors:
You must issue this command against the admin database of the current primary member of the replica set.
You can optionally force the replica set to accept the new conguration by specifying force: true. Use
this option if the current member is not primary or if a majority of the members of the set are not accessible.
Warning: Forcing the replSetReconfig (page 294) command can lead to a rollback situation. Use
with caution.
Use the force option to restore a replica set to new servers with different hostnames. This works even if the set
members already have a copy of the data.
A majority of the sets members must be operational for the changes to propagate properly.
This command can cause downtime as the set renegotiates primary-status. Typically this is 10-20 seconds, but
could be as long as a minute or more. Therefore, you should attempt to recongure only during scheduled
maintenance periods.
In some cases, replSetReconfig (page 294) forces the current primary to step down, initiating an election
for primary among the members of the replica set. When this happens, the set will drop all current connections.
replSetReconfig (page 294) obtains a special mutually exclusive lock to prevent more than one
replSetReconfig (page 294) operation from occurring at the same time.
Additional Information http://docs.mongodb.org/manualreference/replica-configuration,
rs.reconfig() (page 175), and rs.conf() (page 173).
replSetStepDown
Description
replSetStepDown
Forces the primary of the replica set to become a secondary. This initiates an election for primary.
replSetStepDown (page 294) has the following prototype form:
db.runCommand( { replSetStepDown: <seconds> , force: <true|false> } )
replSetStepDown (page 294) has the following elds:
294 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld number replSetStepDown A number of seconds for the member to avoid election to primary.
If you do not specify a value for <seconds>, replSetStepDown (page 294) will attempt
to avoid reelection to primary for 60 seconds.
eld Boolean force New in version 2.0: Forces the primary to step down even if there are no sec-
ondary members within 10 seconds of the primarys latest optime.
Warning: replSetStepDown (page 294) forces all clients currently connected to the database to dis-
connect. This helps ensure that clients maintain an accurate view of the replica set.
New in version 2.0: If there is no secondary within 10 seconds of the primary, replSetStepDown (page 294)
will not succeed to prevent long running elections.
Example The following example species that the former primary avoids reelection to primary for 120 seconds:
db.runCommand( { replSetStepDown: 120 } )
replSetSyncFrom
Description
replSetSyncFrom
New in version 2.2.
Explicitly congures which host the current mongod (page 555) pulls oplog entries from. This operation is
useful for testing different patterns and in situations where a set member is not replicating from the desired host.
The replSetSyncFrom (page 295) command has the following form:
{ replSetSyncFrom: "hostname<:port>" }
The replSetSyncFrom (page 295) command has the following eld:
eld string replSetSyncFrom The name and port number of the replica set member that this mem-
ber should replicate from. Use the [hostname]:[port] form.
For more information the use of replSetSyncFrom (page 295), see
http://docs.mongodb.org/manualtutorial/configure-replica-set-secondary-sync-target.
resync
resync
The resync (page 295) command forces an out-of-date slave mongod (page 555) instance to re-synchronize
itself. Note that this command is relevant to master-slave replication only. It does not apply to replica sets.
Warning: This command obtains a global write lock and will block other operations until it has completed.
See also:
http://docs.mongodb.org/manualreplication for more information regarding replication.
2.2. Database Commands 295
MongoDB Reference Manual, Release 2.6.4
Sharding Commands
Sharding Commands
Name Description
addShard (page 296) Adds a shard to a sharded cluster.
checkShardingIndex
(page 297)
Internal command that validates index on shard key.
cleanupOrphaned
(page 298)
Removes orphaned data with shard key values outside of the ranges of the chunks
owned by a shard.
enableSharding
(page 300)
Enables sharding on a specic database.
flushRouterConfig
(page 301)
Forces an update to the cluster metadata cached by a mongos (page 571).
getShardMap
(page 301)
Internal command that reports on the state of a sharded cluster.
getShardVersion
(page 301)
Internal command that returns the cong server version.
isdbgrid (page 301) Veries that a process is a mongos (page 571).
listShards
(page 302)
Returns a list of congured shards.
medianKey (page 302) Deprecated internal command. See splitVector (page 309).
mergeChunks
(page 302)
Provides the ability to combine chunks on a single shard.
moveChunk (page 303) Internal command that migrates chunks between shards.
movePrimary
(page 304)
Reassigns the primary shard when removing a shard from a sharded cluster.
removeShard
(page 305)
Starts the process of removing a shard from a sharded cluster.
setShardVersion
(page 306)
Internal command to sets the cong server version.
shardCollection
(page 307)
Enables the sharding functionality for a collection, allowing the collection to be
sharded.
shardingState
(page 308)
Reports whether the mongod (page 555) is a member of a sharded cluster.
splitChunk
(page 308)
Internal command to split chunk. Instead use the methods sh.splitFind()
(page 189) and sh.splitAt() (page 188).
splitVector
(page 309)
Internal command that determines split points.
split (page 309) Creates a new chunk.
unsetSharding
(page 311)
Internal command that affects connections between instances in a MongoDB
deployment.
addShard
Denition
addShard
Adds either a database instance or a replica set to a sharded cluster. The optimal conguration is to deploy
shards across replica sets.
Run addShard (page 296) when connected to a mongos (page 571) instance. The command takes the fol-
lowing form when adding a single database instance as a shard:
296 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ addShard: "<hostname><:port>", maxSize: <size>, name: "<shard_name>" }
When adding a replica set as a shard, use the following form:
{ addShard: "<replica_set>/<hostname><:port>", maxSize: <size>, name: "<shard_name>" }
The command contains the following elds:
eld string addShard The hostname and port of the mongod (page 555) instance to be added as a
shard. To add a replica set as a shard, specify the name of the replica set and the hostname and
port of a member of the replica set.
eld integer maxSize The maximum size in megabytes of the shard. If you set maxSize to 0,
MongoDB does not limit the size of the shard.
eld string name A name for the shard. If this is not specied, MongoDB automatically provides a
unique name.
The addShard (page 296) command stores shard conguration information in the cong database. Always
run addShard (page 296) when using the admin database.
Specify a maxSize when you have machines with different disk capacities, or if you want to limit the amount
of data on some shards. The maxSize constraint prevents the balancer from migrating chunks to the shard
when the value of mem.mapped (page 359) exceeds the value of maxSize.
Considerations
Balancing When you add a shard to a sharded cluster, you affect the balance of chunks among the shards of a cluster
for all existing sharded collections. The balancer will begin migrating chunks so that the cluster will achieve balance.
See http://docs.mongodb.org/manualcore/sharding-balancing for more information.
Hidden Members
Important: You cannot include a hidden member in the seed list provided to addShard (page 296).
Examples The following command adds the database instance running on port 27027 on the host
mongodb0.example.net as a shard:
use admin
db.runCommand({addShard: "mongodb0.example.net:27027"})
Warning: Do not use localhost for the hostname unless your conguration server is also running on
localhost.
The following command adds a replica set as a shard:
use admin
db.runCommand( { addShard: "repl0/mongodb3.example.net:27327"} )
You may specify all members in the replica set. All additional hostnames must be members of the same replica set.
checkShardingIndex
checkShardingIndex
checkShardingIndex (page 297) is an internal command that supports the sharding functionality.
2.2. Database Commands 297
MongoDB Reference Manual, Release 2.6.4
cleanupOrphaned
Denition
cleanupOrphaned
New in version 2.6.
Deletes from a shard the orphaned documents whose shard key values fall into a single or a single contiguous
range that do not belong to the shard. For example, if two contiguous ranges do not belong to the shard, the
cleanupOrphaned (page 298) examines both ranges for orphaned documents.
cleanupOrphaned (page 298) has the following syntax:
db.runCommand( {
cleanupOrphaned: "<database>.<collection>",
startingAtKey: <minimumShardKeyValue>,
secondaryThrottle: <boolean>
} )
cleanupOrphaned (page 298) has the following elds:
eld string cleanupOrphaned The namespace, i.e. both the database and the collection name, of
the sharded collection for which to clean the orphaned data.
eld document startingAtKey The shard key value that determines the lower bound of the cleanup
range. The default value is MinKey.
If the range that contains the specied startingAtKey value belongs to a chunk owned by
the shard, cleanupOrphaned (page 298) continues to examine the next ranges until it nds
a range not owned by the shard. See Determine Range (page 298) for details.
eld boolean secondaryThrottle If true, each delete operation must be replicated to another sec-
ondary before the cleanup operation proceeds further. If false, do not wait for replication.
Defaults to false.
Independent of the secondaryThrottle setting, after the nal delete,
cleanupOrphaned (page 298) waits for all deletes to replicate to a majority of replica set
members before returning.
Behavior Run cleanupOrphaned (page 298) in the admin database directly on the mongod (page 555) instance
that is the primary replica set member of the shard. Do not run cleanupOrphaned (page 298) on a mongos
(page 571) instance.
You do not need to disable the balancer before running cleanupOrphaned (page 298).
Determine Range The cleanupOrphaned (page 298) command uses the startingAtKey value, if specied,
to determine the start of the range to examine for orphaned document:
If the startingAtKey value falls into a range for a chunk not owned by the shard, cleanupOrphaned
(page 298) begins examining at the start of this range, which may not necessarily be the startingAtKey.
If the startingAtKey value falls into a range for a chunk owned by the shard, cleanupOrphaned
(page 298) moves onto the next range until it nds a range for a chunk not owned by the shard.
The cleanupOrphaned (page 298) deletes orphaned documents from the start of the determined range and ends at
the start of the chunk range that belongs to the shard.
Consider the following key space with documents distributed across Shard A and Shard B.
Shard A owns:
298 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Figure 2.1: Diagram of shard key value space, showing chunk ranges and shards.
Chunk 1 with the range { x: minKey } --> { x: -75 },
Chunk 2 with the range { x: -75 } --> { x: 25 }, and
Chunk 4 with the range { x: 175 } --> { x: 200 }.
Shard B owns:
Chunk 3 with the range { x: 25 } --> { x: 175 } and
Chunk 5 with the range { x: 200 } --> { x: maxKey }.
If on Shard A, the cleanupOrphaned (page 298) command runs with startingAtKey: { x: -70 }
or any other value belonging to range for Chunk 1 or Chunk 2, the cleanupOrphaned (page 298) command
examines the Chunk 3 range of { x: 25 } --> { x: 175 } to delete orphaned data.
If on Shard B, the cleanupOrphaned (page 298) command runs with the startingAtKey: { x: -70
} or any other value belonging to range for Chunk 1, the cleanupOrphaned (page 298) command examines
the combined contiguous range for Chunk 1 and Chunk 2, namely { x: minKey } --> { x: 25 } to
delete orphaned data.
Required Access On systems running with authorization, you must have clusterAdmin privileges to run
cleanupOrphaned (page 298).
Output
Return Document Each cleanupOrphaned (page 298) command returns a document containing a subset of the
following elds:
cleanupOrphaned.ok
Equal to 1 on success.
A value of 1 indicates that cleanupOrphaned (page 298) scanned the specied shard key range, deleted any
orphaned documents found in that range, and conrmed that all deletes replicated to a majority of the members
of that shards replica set. If conrmation does not arrive within 1 hour, cleanupOrphaned (page 298) times
out.
A value of 0 could indicate either of two cases:
cleanupOrphaned (page 298) found orphaned documents on the shard but could not delete them.
cleanupOrphaned (page 298) found and deleted orphaned documents, but could not conrm replica-
tion before the 1 hour timeout. In this case, replication does occur, but only after cleanupOrphaned
(page 298) returns.
cleanupOrphaned.stoppedAtKey
The upper bound of the cleanup range of shard keys. If present, the value corresponds to the lower bound of the
next chunk on the shard. The absence of the eld signies that the cleanup range was the uppermost range for
the shard.
2.2. Database Commands 299
MongoDB Reference Manual, Release 2.6.4
Log Files The cleanupOrphaned (page 298) command prints the number of deleted documents to the mongod
(page 555) log. For example:
m30000| 2013-10-31T15:17:28.972-0400 [conn1] Deleter starting delete for: foo.bar from { _id: -35.0 } -> { _id: -10.0 }, with opId: 128
m30000| 2013-10-31T15:17:28.972-0400 [conn1] rangeDeleter deleted 0 documents for foo.bar from { _id: -35.0 } -> { _id: -10.0 } { "stoppedAtKey": { "_id": -10 }, "ok": 1 }
Examples The following examples run the cleanupOrphaned (page 298) command directly on the primary of
the shard.
Remove Orphaned Documents for a Specic Range For a sharded collection info in the test database, a shard
owns a single chunk with the range: { x: MinKey } --> { x: 10 }.
The shard also contains documents whose shard keys values fall in a range for a chunk not owned by the shard: { x:
10 } --> { x: MaxKey }.
To remove orphaned documents within the { x: 10 } => { x: MaxKey } range, you can specify a
startingAtKey with a value that falls into this range, as in the following example:
use admin
db.runCommand( {
"cleanupOrphaned": "test.info",
"startingAtKey": { x: 10 },
"secondaryThrottle": true
} )
Or you can specify a startingAtKey with a value that falls into the previous range, as in the following:
use admin
db.runCommand( {
"cleanupOrphaned": "test.info",
"startingAtKey": { x: 2 },
"secondaryThrottle": true
} )
Since { x: 2 } falls into a range that belongs to a chunk owned by the shard, cleanupOrphaned (page 298)
examines the next range to nd a range not owned by the shard, in this case { x: 10 } => { x: MaxKey
}.
Remove All Orphaned Documents from a Shard cleanupOrphaned (page 298) examines documents from
a single contiguous range of shard keys. To remove all orphaned documents from the shard, you can run
cleanupOrphaned (page 298) in a loop, using the returned stoppedAtKey as the next startingFromKey,
as in the following:
use admin
var nextKey = { };
while ( nextKey = db.runCommand( {
cleanupOrphaned: "test.user",
startingFromKey: nextKey
} ).stoppedAtKey ) {
printjson(nextKey);
}
enableSharding
300 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
enableSharding
The enableSharding (page 300) command enables sharding on a per-database level. Use the following
command form:
{ enableSharding: "<database name>" }
Once youve enabled sharding in a database, you can use the shardCollection (page 307) command to
begin the process of distributing data among the shards.
ushRouterCong
flushRouterConfig
flushRouterConfig (page 301) clears the current cluster information cached by a mongos (page 571)
instance and reloads all sharded cluster metadata from the cong database.
This forces an update when the conguration database holds data that is newer than the data cached in the
mongos (page 571) process.
Warning: Do not modify the cong data, except as explicitly documented. A cong database cannot
typically tolerate manual manipulation.
flushRouterConfig (page 301) is an administrative command that is only available for mongos
(page 571) instances.
New in version 1.8.2.
getShardMap
getShardMap
getShardMap (page 301) is an internal command that supports the sharding functionality.
getShardVersion
getShardVersion
getShardVersion (page 301) is a command that supports sharding functionality and is not part of the stable
client facing API.
isdbgrid
isdbgrid
This command veries that a process is a mongos (page 571).
If you issue the isdbgrid (page 301) command when connected to a mongos (page 571), the response
document includes the isdbgrid eld set to 1. The returned document is similar to the following:
{ "isdbgrid" : 1, "hostname" : "app.example.net", "ok" : 1 }
If you issue the isdbgrid (page 301) command when connected to a mongod (page 555), MongoDB returns
an error document. The isdbgrid (page 301) command is not available to mongod (page 555). The error
document, however, also includes a line that reads "isdbgrid" : 1, just as in the document returned for a
mongos (page 571). The error document is similar to the following:
{
"errmsg" : "no such cmd: isdbgrid",
"bad cmd" : {
"isdbgrid" : 1
},
"ok" : 0
}
2.2. Database Commands 301
MongoDB Reference Manual, Release 2.6.4
You can instead use the isMaster (page 287) command to determine connection to a mongos (page 571).
When connected to a mongos (page 571), the isMaster (page 287) command returns a document that con-
tains the string isdbgrid in the msg eld.
listShards
listShards
Use the listShards (page 302) command to return a list of congured shards. The command takes the
following form:
{ listShards: 1 }
medianKey
medianKey
medianKey (page 302) is an internal command.
mergeChunks
Denition
mergeChunks
For a sharded collection, mergeChunks (page 302) combines two contiguous chunk ranges the same shard
into a single chunk. At least one of chunk must not have any documents. Issue the mergeChunks (page 302)
command from a mongos (page 571) instance.
mergeChunks (page 302) has the following form:
db.runCommand( { mergeChunks : <namespace> ,
bounds : [ { <shardKeyField>: <minFieldValue> },
{ <shardKeyField>: <maxFieldValue> } ] } )
For compound shard keys, you must include the full shard key in the bounds specication. If the shard key is
{ x: 1, y: 1 }, mergeChunks (page 302) has the following form:
db.runCommand( { mergeChunks : <namespace> ,
bounds : [ { x: <minValue>, y: <minValue> },
{ x: <maxValue>, y: <maxValue> } ] } )
The mergeChunks (page 302) command has the following elds:
eld namespace mergeChunks The fully qualied namespace of the collection where both chunks
exist. Namespaces take form of <database>.<collection>.
eld array bounds An array that contains the minimum and maximum key values of the new chunk.
Behavior
Note: Use the mergeChunks (page 302) only in special circumstances such as cleaning up your sharded cluster
after removing many documents.
In order to successfully merge chunks, the following must be true
In the bounds eld, <minkey> and <maxkey> must correspond to the lower and upper bounds of the chunks
to merge.
The two chunks must reside on the same shard.
The two chunks must be contiguous.
302 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
One or both chunks must be empty.
mergeChunks (page 302) returns an error if these conditions are not satised.
Return Messages On success, mergeChunks (page 302) returns to following document:
{ "ok" : 1 }
Another Operation in Progress mergeChunks (page 302) returns the following error message if another meta-
data operation is in progress on the chunks (page 649) collection:
errmsg: "The collection's metadata lock is already taken."
If another process, such as balancer process, changes metadata while mergeChunks (page 302) is running, you may
see this error. You can retry the mergeChunks (page 302) operation without side effects.
Chunks on Different Shards If the input chunks are not on the same shard, mergeChunks (page 302) returns an
error similar to the following:
{
"ok" : 0,
"errmsg" : "could not merge chunks, collection test.users does not contain a chunk ending at { username: \"user63169\" }"
}
Noncontiguous Chunks If the input chunks are not contiguous, mergeChunks (page 302) returns an error similar
to the following:
{
"ok" : 0,
"errmsg" : "could not merge chunks, collection test.users has more than 2 chunks between [{ username: \"user29937\" }, { username: \"user49877\" })"
}
Documents in Both Chunks If neither input chunk is empty, mergeChunks (page 302) returns an error similar to
the following:
{
"ok" : 0,
"errmsg" : "could not merge chunks, collection test.users has more than one non-empty chunk between [{ username: \"user36583\" }, { username: \"user49877\" })"
}
moveChunk
Denition
moveChunk
Internal administrative command. Moves chunks between shards. Issue the moveChunk (page 303) command
via a mongos (page 571) instance while using the admin database. Use the following forms:
db.runCommand( { moveChunk : <namespace> ,
find : <query> ,
to : <string>,
_secondaryThrottle : <boolean>,
_waitForDelete : <boolean> } )
2.2. Database Commands 303
MongoDB Reference Manual, Release 2.6.4
Alternately:
db.runCommand( { moveChunk : <namespace> ,
bounds : <array> ,
to : <string>,
_secondaryThrottle : <boolean>,
_waitForDelete : <boolean> } )
The moveChunk (page 303) command has the following elds:
eld string moveChunk The namespace of the collection where the chunk exists. Specify the col-
lections full namespace, including the database name.
eld document nd An equality match on the shard key that species the shard-key value of the
chunk to move. Specify either the bounds eld or the find eld but not both.
eld array bounds The bounds of a specic chunk to move. The array must consist of two doc-
uments that specify the lower and upper shard key values of a chunk to move. Specify either
the bounds eld or the find eld but not both. Use bounds to move chunks in collections
partitioned using a hashed shard key.
eld string to The name of the destination shard for the chunk.
eld Boolean _secondaryThrottle Defaults to true. When true, the balancer waits for replica-
tion to secondaries when it copies and deletes data during chunk migrations. For details, see
sharded-cluster-cong-secondary-throttle.
eld Boolean _waitForDelete Internal option for testing purposes. The default is false. If set to
true, the delete phase of a moveChunk (page 303) operation blocks.
The value of bounds takes the form:
[ { hashedField : <minValue> } ,
{ hashedField : <maxValue> } ]
The chunk migration section describes how chunks move between shards on MongoDB.
See also:
split (page 309), sh.moveChunk() (page 186), sh.splitAt() (page 188), and sh.splitFind()
(page 189).
Return Messages moveChunk (page 303) returns the following error message if another metadata operation is in
progress on the chunks (page 649) collection:
errmsg: "The collection's metadata lock is already taken."
If another process, such as a balancer process, changes meta data while moveChunk (page 303) is running, you may
see this error. You may retry the moveChunk (page 303) operation without side effects.
Note: Only use the moveChunk (page 303) in special circumstances such as prepar-
ing your sharded cluster for an initial ingestion of data, or a large bulk import opera-
tion. In most cases allow the balancer to create and balance chunks in sharded clusters. See
http://docs.mongodb.org/manualtutorial/create-chunks-in-sharded-cluster for
more information.
movePrimary
304 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
movePrimary
In a sharded cluster, movePrimary (page 304) reassigns the primary shard which holds all un-sharded col-
lections in the database. movePrimary (page 304) rst changes the primary shard in the cluster metadata, and
then migrates all un-sharded collections to the specied shard. Use the command with the following form:
{ movePrimary : "test", to : "shard0001" }
When the command returns, the databases primary location will shift to the designated shard. To fully decom-
mission a shard, use the removeShard (page 305) command.
movePrimary (page 304) is an administrative command that is only available for mongos (page 571) in-
stances.
Considerations
Behavior Avoid accessing an un-sharded collection during migration. movePrimary (page 304) does not prevent
reading and writing during its operation, and such actions yield undened behavior.
movePrimary (page 304) may take signicant time to complete, and you should plan for this unavailability.
movePrimary (page 304) will fail if the destination shard contains a conicting collection name. This may occur if
documents are written to an un-sharded collection while the collection is moved away, and later the original primary
shard is restored.
Use If you use the movePrimary (page 304) command to move un-sharded collections, you must either restart all
mongos (page 571) instances, or use the flushRouterConfig (page 301) command on all mongos (page 571)
instances before writing any data to the cluster. This action noties the mongos (page 571) of the new shard for the
database.
If you do not update the mongos (page 571) instances metadata cache after using movePrimary (page 304), the
mongos (page 571) may not write data to the correct shard. To recover, you must manually intervene.
Additional Information See http://docs.mongodb.org/manualtutorial/remove-shards-from-cluster
for a complete procedure.
removeShard
removeShard
Removes a shard from a sharded cluster. When you run removeShard (page 305), MongoDB rst moves the
shards chunks to other shards in the cluster. Then MongoDB removes the shard.
Behavior
Access Requirements You must run removeShard (page 305) while connected to a mongos (page 571). Issue
the command against the admin database or use the sh._adminCommand() (page 181) helper.
If you have authorization enabled, you must have the clusterManager role or any role that includes the
removeShard action.
2.2. Database Commands 305
MongoDB Reference Manual, Release 2.6.4
Database Migration Requirements Each database in a sharded cluster has a primary shard. If the shard you
want to remove is also the primary of one of the clusters databases, then you must manually move the databases
to a new shard after migrating all data from the shard. See the movePrimary (page 304) command and the
http://docs.mongodb.org/manualtutorial/remove-shards-from-cluster for more informa-
tion.
Example From the mongo (page 580) shell, the removeShard (page 305) operation resembles the following:
use admin
db.runCommand( { removeShard : "bristol01" } )
Replace bristol01 with the name of the shard to remove. When you run removeShard (page 305), the command
returns immediately, with the following message:
{
"msg" : "draining started successfully",
"state" : "started",
"shard" : "bristol01",
"ok" : 1
}
The balancer begins migrating chunks from the shard named bristol01 to other shards in the cluster. These
migrations happens slowly to avoid placing undue load on the overall cluster.
If you run the command again, removeShard (page 305) returns the following progress output:
{
"msg" : "draining ongoing",
"state" : "ongoing",
"remaining" : {
"chunks" : 23,
"dbs" : 1
},
"ok" : 1
}
The remaining document species how many chunks and databases remain on the shard. Use
db.printShardingStatus() (page 122) to list the databases that you must move from the shard. Use the
movePrimary (page 304) to move databases.
After removing all chunks and databases from the shard, you can issue removeShard (page 305) again see the
following:
{
"msg" : "removeshard completed successfully",
"state" : "completed",
"shard" : "bristol01",
"ok" : 1
}
setShardVersion
setShardVersion
setShardVersion (page 306) is an internal command that supports sharding functionality.
shardCollection
306 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Denition
shardCollection
Enables a collection for sharding and allows MongoDB to begin distributing data among shards. You must run
enableSharding (page 300) on a database before running the shardCollection (page 307) command.
shardCollection (page 307) has the following form:
{ shardCollection: "<database>.<collection>", key: <shardkey> }
shardCollection (page 307) has the following elds:
eld string shardCollection The namespace of the collection to shard in the form
<database>.<collection>.
eld document key The index specication document to use as the shard key. The index must exist
prior to the shardCollection (page 307) command, unless the collection is empty. If the
collection is empty, in which case MongoDB creates the index prior to sharding the collection.
New in version 2.4: The key may be in the form { field : "hashed" }, which will use
the specied eld as a hashed shard key.
eld Boolean unique When true, the unique option ensures that the underlying index enforces
a unique constraint. Hashed shard keys do not support unique constraints.
eld integer numInitialChunks Species the number of chunks to create initially when sharding an
empty collection with a hashed shard key. MongoDB will then create and balance chunks across
the cluster. The numInitialChunks must be less than 8192 per shard. If the collection is
not empty, numInitialChunks has no effect.
Considerations
Use Do not run more than one shardCollection (page 307) command on the same collection at the same time.
MongoDB provides no method to deactivate sharding for a collection after calling shardCollection (page 307).
Additionally, after shardCollection (page 307), you cannot change shard keys or modify the value of any eld
used in your shard key index.
Shard Keys Choosing the best shard key to effectively distribute load among your shards requires some planning.
Review sharding-shard-key regarding choosing a shard key.
Hashed Shard Keys New in version 2.4.
Hashed shard keys use a hashed index of a single eld as the shard key.
Note: If chunk migrations are in progress while creating a hashed shard key collection, the initial chunk distribution
may be uneven until the balancer automatically balances the collection.
Example The following operation enables sharding for the people collection in the records database and uses
the zipcode eld as the shard key:
db.runCommand( { shardCollection: "records.people", key: { zipcode: 1 } } )
Additional Information http://docs.mongodb.org/manualsharding,
http://docs.mongodb.org/manualcore/sharding, and http://docs.mongodb.org/manualtutorial/deploy-shard-cluster.
2.2. Database Commands 307
MongoDB Reference Manual, Release 2.6.4
shardingState
shardingState
shardingState (page 308) is an admin command that reports if mongod (page 555) is a member of a
sharded cluster. shardingState (page 308) has the following prototype form:
{ shardingState: 1 }
For shardingState (page 308) to detect that a mongod (page 555) is a member of a sharded cluster, the
mongod (page 555) must satisfy the following conditions:
1.the mongod (page 555) is a primary member of a replica set, and
2.the mongod (page 555) instance is a member of a sharded cluster.
If shardingState (page 308) detects that a mongod (page 555) is a member of a sharded cluster,
shardingState (page 308) returns a document that resembles the following prototype:
{
"enabled" : true,
"configServer" : "<configdb-string>",
"shardName" : "<string>",
"shardHost" : "string:",
"versions" : {
"<database>.<collection>" : Timestamp(<...>),
"<database>.<collection>" : Timestamp(<...>)
},
"ok" : 1
}
Otherwise, shardingState (page 308) will return the following document:
{ "note" : "from execCommand", "ok" : 0, "errmsg" : "not master" }
The response from shardingState (page 308) when used with a cong server is:
{ "enabled": false, "ok": 1 }
Note: mongos (page 571) instances do not provide the shardingState (page 308).
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed; however, the operation is typically short lived.
splitChunk
Denition
splitChunk
An internal administrative command. To split chunks, use the sh.splitFind() (page 189) and
sh.splitAt() (page 188) functions in the mongo (page 580) shell.
Warning: Be careful when splitting data in a sharded collection to create new chunks. When you shard a
collection that has existing data, MongoDB automatically creates chunks to evenly distribute the collection.
To split data effectively in a sharded cluster you must consider the number of documents in a chunk and the
average document size to create a uniform chunk size. When chunks have irregular sizes, shards may have
an equal number of chunks but have very different data sizes. Avoid creating splits that lead to a collection
with differently sized chunks.
308 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
See also:
moveChunk (page 303) and sh.moveChunk() (page 186).
The splitChunk (page 308) command takes a document with the following elds:
eld string ns The complete namespace of the chunk to split.
eld document keyPattern The shard key.
eld document min The lower bound of the shard key for the chunk to split.
eld document max The upper bound of the shard key for the chunk to split.
eld string from The shard that owns the chunk to split.
eld document splitKeys The split point for the chunk.
eld document shardId The shard.
splitVector
splitVector
Is an internal command that supports meta-data operations in sharded clusters.
split
Denition
split
Splits a chunk in a sharded cluster into two chunks. The mongos (page 571) in-
stance splits and manages chunks automatically, but for exceptional circumstances the
split (page 309) command does allow administrators to manually create splits. See
http://docs.mongodb.org/manualtutorial/split-chunks-in-sharded-cluster
for information on these circumstances, and on the MongoDB shell commands that wrap split (page 309).
The split (page 309) command uses the following form:
db.adminCommand( { split: <database>.<collection>,
<find|middle|bounds> } )
The split (page 309) command takes a document with the following elds:
eld string split The name of the collection where the chunk exists. Specify the collections full
namespace, including the database name.
eld document nd An query statement that species an equality match on the shard key. The
match selects the chunk that contains the specied document. You must specify only one of the
following: find, bounds, or middle.
You cannot use the find option on an empty collection.
eld array bounds New in version 2.4: The bounds of a chunk to split. bounds applies to chunks
in collections partitioned using a hashed shard key. The parameters array must consist of two
documents specifying the lower and upper shard-key values of the chunk. The values must match
the minimum and maximum values of an existing chunk. Specify only one of the following:
find, bounds, or middle.
You cannot use the bounds option on an empty collection.
eld document middle The document to use as the split point to create two chunks. split
(page 309) requires one of the following options: find, bounds, or middle.
2.2. Database Commands 309
MongoDB Reference Manual, Release 2.6.4
Considerations When used with either the find or the bounds option, the split (page 309) command splits the
chunk along the median. As such, the command cannot use the find or the bounds option to split an empty chunk
since an empty chunk has no median.
To create splits in empty chunks, use either the middle option with the split (page 309) command or use the
splitAt command.
Command Formats To create a chunk split, connect to a mongos (page 571) instance, and issue the following
command to the admin database:
db.adminCommand( { split: <database>.<collection>,
find: <document> } )
Or:
db.adminCommand( { split: <database>.<collection>,
middle: <document> } )
Or:
db.adminCommand( { split: <database>.<collection>,
bounds: [ <lower>, <upper> ] } )
To create a split for a collection that uses a hashed shard key, use the bounds parameter. Do not use the middle
parameter for this purpose.
Warning: Be careful when splitting data in a sharded collection to create new chunks. When you shard a
collection that has existing data, MongoDB automatically creates chunks to evenly distribute the collection. To
split data effectively in a sharded cluster you must consider the number of documents in a chunk and the average
document size to create a uniform chunk size. When chunks have irregular sizes, shards may have an equal number
of chunks but have very different data sizes. Avoid creating splits that lead to a collection with differently sized
chunks.
See also:
moveChunk (page 303), sh.moveChunk() (page 186), sh.splitAt() (page 188), and sh.splitFind()
(page 189), which wrap the functionality of split (page 309).
Examples The following sections provide examples of the split (page 309) command.
Split a Chunk in Half
db.runCommand( { split : "test.people", find : { _id : 99 } } )
The split (page 309) command identies the chunk in the people collection of the test database, that holds
documents that match { _id : 99 }. split (page 309) does not require that a match exist, in order to identify
the appropriate chunk. Then the command splits it into two chunks of equal size.
Note: split (page 309) creates two equal chunks by range as opposed to size, and does not use the selected point
as a boundary for the new chunks
Dene an Arbitrary Split Point To dene an arbitrary split point, use the following form:
db.runCommand( { split : "test.people", middle : { _id : 99 } } )
310 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The split (page 309) command identies the chunk in the people collection of the test database, that would
hold documents matching the query { _id : 99 }. split (page 309) does not require that a match exist, in
order to identify the appropriate chunk. Then the command splits it into two chunks, with the matching document as
the lower bound of one of the split chunks.
This form is typically used when pre-splitting data in a collection.
Split a Chunk Using Values of a Hashed Shard Key This example uses the hashed shard key userid in a
people collection of a test database. The following command uses an array holding two single-eld documents to
represent the minimum and maximum values of the hashed shard key to split the chunk:
db.runCommand( { split: "test.people",
bounds : [ { userid: NumberLong("-5838464104018346494") },
{ userid: NumberLong("-5557153028469814163") }
] } )
Note: MongoDB uses the 64-bit NumberLong type to represent the hashed value.
Use sh.status() (page 189) to see the existing bounds of the shard keys.
Metadata Lock Error If another process in the mongos (page 571), such as a balancer process, changes metadata
while split (page 309) is running, you may see a metadata lock error.
errmsg: "The collection's metadata lock is already taken."
This message indicates that the split has failed with no side effects. Retry the split (page 309) command.
unsetSharding
unsetSharding
unsetSharding (page 311) is an internal command that supports sharding functionality.
See also:
http://docs.mongodb.org/manualsharding for more information about MongoDBs sharding function-
ality.
2.2. Database Commands 311
MongoDB Reference Manual, Release 2.6.4
Instance Administration Commands
Administration Commands
Name Description
clean (page 312) Internal namespace administration command.
cloneCollectionAsCapped
(page 312)
Copies a non-capped collection as a new capped collection.
cloneCollection (page 313) Copies a collection from a remote host to the current host.
clone (page 313) Copies a database from a remote host to the current host.
closeAllDatabases (page 314) Internal command that invalidates all cursors and closes open database
les.
collMod (page 314) Add ags to collection to modify the behavior of MongoDB.
compact (page 316) Defragments a collection and rebuilds the indexes.
connPoolSync (page 318) Internal command to ush connection pool.
convertToCapped (page 318) Converts a non-capped collection to a capped collection.
copydb (page 319) Copies a database from a remote host to the current host.
createIndexes (page 322) Builds one or more indexes for a collection.
create (page 326) Creates a collection and sets collection parameters.
dropDatabase (page 327) Removes the current database.
dropIndexes (page 327) Removes indexes from a collection.
drop (page 327) Removes the specied collection from the database.
filemd5 (page 328) Returns the md5 hash for les stored using GridFS.
fsync (page 328) Flushes pending writes to the storage layer and locks the database to
allow backups.
getParameter (page 330) Retrieves conguration options.
logRotate (page 330) Rotates the MongoDB logs to prevent a single le from taking too
much space.
reIndex (page 330) Rebuilds all indexes on a collection.
renameCollection (page 331) Changes the name of an existing collection.
repairDatabase (page 332) Repairs any errors and inconsistencies with the data storage.
setParameter (page 334) Modies conguration options.
shutdown (page 334) Shuts down the mongod (page 555) or mongos (page 571) process.
touch (page 335) Loads documents and indexes from data storage to memory.
clean
clean
clean (page 312) is an internal command.
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed.
cloneCollectionAsCapped
cloneCollectionAsCapped
The cloneCollectionAsCapped (page 312) command creates a new capped collection from an exist-
ing, non-capped collection within the same database. The operation does not affect the original non-capped
collection.
The command has the following syntax:
{ cloneCollectionAsCapped: <existing collection>, toCollection: <capped collection>, size: <capped size> }
312 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The command copies an existing collection and creates a new capped collection with a max-
imum size specied by the capped size in bytes. The name of the new capped collection must be distinct
and cannot be the same as that of the original existing collection. To replace the original non-capped collection
with a capped collection, use the convertToCapped (page 318) command.
During the cloning, the cloneCollectionAsCapped (page 312) command exhibit the following behavior:
MongoDB will transverse the documents in the original collection in natural order as theyre loaded.
If the capped size specied for the new collection is smaller than the size of the original uncapped
collection, then MongoDB will begin overwriting earlier documents in insertion order, which is rst in,
rst out (e.g FIFO).
cloneCollection
Denition
cloneCollection
Copies a collection from a remote mongod (page 555) instance to the current mongod (page 555) instance.
cloneCollection (page 313) creates a collection in a database with the same name as the remote collec-
tions database. cloneCollection (page 313) takes the following form:
{ cloneCollection: "<namespace>", from: "<hostname>", query: { <query> } }
Important: You cannot clone a collection through a mongos (page 571) but must connect directly to the
mongod (page 555) instance.
cloneCollection (page 313) has the following elds:
eld string cloneCollection The namespace of the collection to rename. The namespace is a com-
bination of the database name and the name of the collection.
eld string from Specify a resolvable hostname and optional port number of the remote server
where the specied collection resides.
eld document query A query that lters the documents in the remote collection that
cloneCollection (page 313) will copy to the current database.
Example
{ cloneCollection: "users.profiles", from: "mongodb.example.net:27017", query: { active: true } }
This operation copies the profiles collection from the users database on the server at
mongodb.example.net. The operation only copies documents that satisfy the query { active: true }.
cloneCollection (page 313) always copies indexes. The query arguments is optional.
If, in the above example, the profiles collection exists in the users database, then MongoDB appends documents
from the remote collection to the destination collection.
clone
clone
The clone (page 313) command clones a database from a remote MongoDB instance to the current host.
clone (page 313) copies the database on the remote instance with the same name as the current database. The
command takes the following form:
{ clone: "db1.example.net:27017" }
2.2. Database Commands 313
MongoDB Reference Manual, Release 2.6.4
Replace db1.example.net:27017 above with the resolvable hostname for the MongoDB instance you
wish to copy from. Note the following behaviors:
clone (page 313) can run against a slave or a non-primary member of a replica set.
clone (page 313) does not snapshot the database. If any clients update the database youre copying at
any point during the clone operation, the resulting database may be inconsistent.
You must run clone (page 313) on the destination server.
The destination server is not locked for the duration of the clone (page 313) operation. This means that
clone (page 313) will occasionally yield to allow other operations to complete.
See copydb (page 319) for similar functionality with greater exibility.
Warning: This command obtains an intermittent write lock on the destination server, which can block other
operations until it completes.
closeAllDatabases
closeAllDatabases
closeAllDatabases (page 314) is an internal command that invalidates all cursors and closes the open
database les. The next operation that uses the database will reopen the le.
Warning: This command obtains a global write lock and will block other operations until it has completed.
collMod
Denition
collMod
New in version 2.2.
collMod (page 314) makes it possible to add ags to a collection to modify the behavior of MongoDB. Flags
include usePowerOf2Sizes (page 314) and index (page 315). The command takes the following prototype
form:
db.runCommand( {"collMod" : <collection> , "<flag>" : <value> } )
In this command substitute <collection> with the name of a collection in the current database, and <flag>
and <value> with the ag and value you want to set.
Use the userFlags (page 339) eld in the db.collection.stats() (page 69) output to check enabled
collection ags.
Flags
Powers of Two Record Allocation
usePowerOf2Sizes
Changed in version 2.6: usePowerOf2Sizes (page 314) became the default allocation strategy for all new
collections. Set newCollectionsUsePowerOf2Sizes to false to select the exact t allocation strategy
for new collections.
The usePowerOf2Sizes (page 314) ag changes the method that MongoDB uses to allocate space on disk
for documents in this collection. By setting usePowerOf2Sizes (page 314), you ensure that MongoDB will
314 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
allocate space for documents in sizes that are powers of 2 (e.g. 32, 64, 128, 256, 512...16777216.) The smallest
allocation for a document is 32 bytes.
With usePowerOf2Sizes (page 314) MongoDB will be able to more effectively reuse space.
With usePowerOf2Sizes (page 314) MongoDB, allocates records that have power of 2 sizes, until record
sizes equal 4 megabytes. For records larger than 4 megabytes with usePowerOf2Sizes (page 314) set,
mongod (page 555) will allocate records in full megabytes by rounding up to the nearest megabyte.
Use usePowerOf2Sizes (page 314) for collections where applications insert and delete large numbers of
documents to avoid storage fragmentation and ensure that MongoDB will effectively use space on disk.
TTL Collection Expiration Time
index
The index (page 315) ag changes the expiration time of a TTL Collection.
Specify the key and new expiration time with a document of the form:
{keyPattern: <index_spec>, expireAfterSeconds: <seconds> }
In this example, <index_spec> is an existing index in the collection and seconds is the number of seconds
to subtract from the current time.
On success collMod (page 314) returns a document with elds expireAfterSeconds_old and
expireAfterSeconds_new set to their respective values.
On failure, collMod (page 314) returns a document with no expireAfterSeconds field to
update if there is no existing expireAfterSeconds eld or cannot find index {
**
key
**
:
1.0 } for ns
**
namespace
**
if the specied keyPattern does not exist.
Examples
Enable Powers of Two Allocation To enable usePowerOf2Sizes (page 314) on the collection named
products, use the following operation:
db.runCommand( {collMod: "products", usePowerOf2Sizes : true })
To disable usePowerOf2Sizes (page 314) on the collection products, use the following operation:
db.runCommand( { collMod: "products", usePowerOf2Sizes: false })
usePowerOf2Sizes (page 314) only affects subsequent allocations caused by document insertion or record relo-
cation as a result of document growth, and does not affect existing allocations.
Change Expiration Value for Indexes To update the expiration value for a collection named sessions indexed
on a lastAccess eld from 30 minutes to 60 minutes, use the following operation:
db.runCommand({collMod: "sessions",
index: {keyPattern: {lastAccess:1},
expireAfterSeconds: 3600}})
Which will return the document:
{ "expireAfterSeconds_old" : 1800, "expireAfterSeconds_new" : 3600, "ok" : 1 }
compact
2.2. Database Commands 315
MongoDB Reference Manual, Release 2.6.4
Denition
compact
New in version 2.0.
Rewrites and defragments all data in a collection, as well as all of the indexes on that collection. compact
(page 316) has the following form:
{ compact: <collection name> }
compact (page 316) has the following elds:
eld string compact The name of the collection.
eld boolean force If true, compact (page 316) can run on the primary in a replica set. If
false, compact (page 316) returns an error when run on a primary, because the command
blocks all other activity. Beginning with version 2.2, compact (page 316) blocks activity only
for the database it is compacting.
eld number paddingFactor Describes the record size allocated for each document as a factor of
the document size for all records compacted during the compact (page 316) operation. The
paddingFactor does not affect the padding of subsequent record allocations after compact
(page 316) completes. For more information, see paddingFactor (page 316).
eld integer paddingBytes Sets the padding as an absolute number of bytes for all records com-
pacted during the compact (page 316) operation. After compact (page 316) completes,
paddingBytes does not affect the padding of subsequent record allocations. For more in-
formation, see paddingBytes (page 317).
compact (page 316) is similar to repairDatabase (page 332); however, repairDatabase (page 332)
operates on an entire database.
Warning: Always have an up-to-date backup before performing server maintenance such as the compact
(page 316) operation.
paddingFactor New in version 2.2.
The paddingFactor eld takes the following range of values:
Default: 1.0
Minimum: 1.0 (no padding)
Maximum: 4.0
If your updates increase the size of the documents, padding will increase the amount of space allocated to each
document and avoid expensive document relocation operations within the data les.
You can calculate the padding size by subtracting the document size from the record size or, in terms of the
paddingFactor, by subtracting 1 from the paddingFactor:
padding size = (paddingFactor - 1)
*
<document size>.
For example, a paddingFactor of 1.0 species a padding size of 0 whereas a paddingFactor of 1.2 species
a padding size of 0.2 or 20 percent (20%) of the document size.
With the following command, you can use the paddingFactor option of the compact (page 316) command to
set the record size to 1.1 of the document size, or a padding factor of 10 percent (10%):
db.runCommand ( { compact: '<collection>', paddingFactor: 1.1 } )
316 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
compact (page 316) compacts existing documents but does not reset paddingFactor statistics for the collection.
After the compact (page 316) MongoDB will use the existing paddingFactor when allocating new records for
documents in this collection.
paddingBytes New in version 2.2.
Specifying paddingBytes can be useful if your documents start small but then increase in size signicantly. For
example, if your documents are initially 40 bytes long and you grow them by 1KB, using paddingBytes: 1024
might be reasonable since using paddingFactor: 4.0 would specify a record size of 160 bytes (4.0 times
the initial document size), which would only provide a padding of 120 bytes (i.e. record size of 160 bytes minus the
document size).
With the following command, you can use the paddingBytes option of the compact (page 316) command to set
the padding size to 100 bytes on the collection named by <collection>:
db.runCommand ( { compact: '<collection>', paddingBytes: 100 } )
Behaviors
Blocking In MongoDB 2.2, compact (page 316) blocks activities only for its database. Prior to 2.2, the command
blocked all activities.
You may view the intermediate progress either by viewing the mongod (page 555) log le or by running the
db.currentOp() (page 107) in another shell instance.
Operation Termination If you terminate the operation with the db.killOp() (page 120) method or restart the
server before the compact (page 316) operation has nished:
If you have journaling enabled, the data remains valid and usable, regardless of the state of the compact
(page 316) operation. You may have to manually rebuild the indexes.
If you do not have journaling enabled and the mongod (page 555) or compact (page 316) terminates during
the operation, it is impossible to guarantee that the data is in a valid state.
In either case, much of the existing free space in the collection may become un-reusable. In this scenario, you
should rerun the compaction to completion to restore the use of this free space.
Disk Space compact (page 316) generally uses less disk space than repairDatabase (page 332) and is faster.
However, the compact (page 316) command is still slow and blocks other database use. Only use compact
(page 316) during scheduled maintenance periods.
compact (page 316) requires up to 2 gigabytes of additional disk space while running. Unlike repairDatabase
(page 332), compact (page 316) does not free space on the le system.
To see how the storage space changes for the collection, run the collStats (page 338) command before and after
compaction.
Size and Number of Data Files compact (page 316) may increase the total size and number of your data les,
especially when run for the rst time. However, this will not increase the total collection storage space since storage
size is the amount of data allocated within the database les, and not the size/number of the les on the le system.
2.2. Database Commands 317
MongoDB Reference Manual, Release 2.6.4
Replica Sets compact (page 316) commands do not replicate to secondaries in a replica set:
Compact each member separately.
Ideally run compact (page 316) on a secondary. See option force:true above for information regarding
compacting the primary.
On secondaries, the compact (page 316) command forces the secondary to enter RECOVERING state. Read
operations issued to an instance in the RECOVERING state will fail. This prevents clients from reading during
the operation. When the operation completes, the secondary returns to:replstate:SECONDARY state.
See http://docs.mongodb.org/manualreference/replica-states/ for more information
about replica set member states.
See http://docs.mongodb.org/manualtutorial/perform-maintence-on-replica-set-members
for an example replica set maintenance procedure to maximize availability during maintenance operations.
Sharded Clusters compact (page 316) is a command issued to a mongod (page 555). In a sharded environment,
run compact (page 316) on each shard separately as a maintenance operation.
You cannot issue compact (page 316) against a mongos (page 571) instance.
Capped Collections It is not possible to compact capped collections because they dont have padding, and docu-
ments cannot grow in these collections. However, the documents of a capped collection are not subject to fragmenta-
tion.
Index Building New in version 2.6.
mongod (page 555) rebuilds all indexes in parallel following the compact (page 316) operation.
connPoolSync
connPoolSync
connPoolSync (page 318) is an internal command.
convertToCapped
convertToCapped
The convertToCapped (page 318) command converts an existing, non-capped collection to a capped col-
lection within the same database.
The command has the following syntax:
{convertToCapped: <collection>, size: <capped size> }
convertToCapped (page 318) takes an existing collection (<collection>) and transforms it into a
capped collection with a maximum size in bytes, specied to the size argument (<capped size>).
During the conversion process, the convertToCapped (page 318) command exhibit the following behavior:
MongoDB transverses the documents in the original collection in natural order and loads the documents
into a new capped collection.
If the capped size specied for the capped collection is smaller than the size of the original uncapped
collection, then MongoDB will overwrite documents in the capped collection based on insertion order, or
rst in, rst out order.
Internally, to convert the collection, MongoDB uses the following procedure
318 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
cloneCollectionAsCapped (page 312) command creates the capped collection and imports the
data.
MongoDB drops the original collection.
renameCollection (page 331) renames the new capped collection to the name of the original
collection.
Note: MongoDB does not support the convertToCapped (page 318) command in a sharded cluster.
Warning: The convertToCapped (page 318) will not recreate indexes from the original collection on
the new collection, other than the index on the _id eld. If you need indexes on this collection you will
need to create these indexes after the conversion is complete.
See also:
create (page 326)
Warning: This command obtains a global write lock and will block other operations until it has completed.
copydb
Denition
copydb
Copies a database from a remote host to the current host or copies a database to another database within the
current host. Run copydb (page 319) in the admin database of the destination server with the following
syntax:
{ copydb: 1,
fromhost: <hostname>,
fromdb: <database>,
todb: <database>,
slaveOk: <bool>,
username: <username>,
nonce: <nonce>,
key: <key> }
copydb (page 319) accepts the following options:
eld string fromhost Hostname of the remote source mongod (page 555) instance. Omit
fromhost to copy from one database to another on the same server.
eld string fromdb Name of the source database.
eld string todb Name of the target databases.
eld boolean slaveOk Set slaveOK to true to allow copydb (page 319) to copy data from sec-
ondary members as well as the primary. fromhost must also be set.
eld string username The username credentials on the fromhost MongoDB deployment.
eld string nonce A single use shared secret generated on the remote server, i.e. fromhost, using
the copydbgetnonce (page 262) command. See Authentication (page 321) for details.
eld string key A hash of the password used for authentication. See Authentication (page 321) for
details.
2.2. Database Commands 319
MongoDB Reference Manual, Release 2.6.4
The mongo (page 580) shell provides the db.copyDatabase() (page 104) wrapper for the copydb
(page 319) command.
Behavior Be aware of the following properties of copydb (page 319):
copydb (page 319) runs on the destination mongod (page 555) instance, i.e. the host receiving the copied
data.
copydb (page 319) creates the target database if it does not exist.
copydb (page 319) requires enough free disk space on the host instance for the copied database. Use the
db.stats() (page 126) operation to check the size of the database on the source mongod (page 555) instance.
copydb (page 319) and clone (page 313) do not produce point-in-time snapshots of the source database.
Write trafc to the source or destination database during the copy process will result in divergent data sets.
copydb (page 319) does not lock the destination server during its operation, so the copy will occasionally yield
to allow other operations to complete.
Required Access Changed in version 2.6.
On systems running with authorization, the copydb (page 319) command requires the following authorization
on the target and source databases.
Source Database (fromdb)
Source is non-admin Database If the source database is a non-admin database, you must have privileges that
specify find action on the source database, and find action on the system.js collection in the source database.
For example:
{ resource: { db: "mySourceDB", collection: "" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.js" }, actions: [ "find" ] }
If the source database is on a remote server, you also need the find action on the system.indexes and
system.namespaces collections in the source database; e.g.
{ resource: { db: "mySourceDB", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "mySourceDB", collection: "system.namespaces" }, actions: [ "find" ] }
Source is admin Database If the source database is the admin database, you must have privileges that specify
find action on the admin database, and find action on the system.js, system.users, system.roles,
and system.version collections in the admin database. For example:
{ resource: { db: "admin", collection: "" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.js" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.roles" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find" ] }
If the source database is on a remote server, the you also need the find action on the system.indexes and
system.namespaces collections in the admin database; e.g.
{ resource: { db: "admin", collection: "system.indexes" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.namespaces" }, actions: [ "find" ] }
320 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Source Database is on a Remote Server If copying from a remote server and the remote server has authentica-
tion enabled, you must authenticate to the remote host as a user with the proper authorization. See Authentication
(page 321).
Target Database (todb)
Copy from non-admin Database If the source database is not the admin database, you must have privileges
that specify insert and createIndex actions on the target database, and insert action on the system.js
collection in the target database. For example:
{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] }
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] }
Copy from admin Database If the source database is the admin database, you must have privileges that
specify insert and createIndex actions on the target database, and insert action on the system.js,
system.users, system.roles, and system.version collections in the target database. For example:
{ resource: { db: "myTargetDB", collection: "" }, actions: [ "insert", "createIndex" ] },
{ resource: { db: "myTargetDB", collection: "system.js" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.users" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.roles" }, actions: [ "insert" ] },
{ resource: { db: "myTargetDB", collection: "system.version" }, actions: [ "insert" ] }
Authentication If copying from a remote server and the remote server has authentication enabled, then you must
include a username, nonce, and key.
The nonce is a one-time password that you request from the remote server using the copydbgetnonce (page 262)
command, as in the following:
use admin
mynonce = db.runCommand( { copydbgetnonce : 1, fromhost: <hostname> } ).nonce
If running the copydbgetnonce (page 262) command directly on the remote host, you can omit the fromhost
eld in the copydbgetnonce (page 262) command.
The key is a hash generated as follows:
hex_md5(mynonce + username + hex_md5(username + ":mongo:" + password))
Replica Sets With read preference congured to set the slaveOk option to true, you may run copydb (page 319)
on a secondary member of a replica set.
Sharded Clusters
Do not use copydb (page 319) from a mongos (page 571) instance.
Do not use copydb (page 319) to copy databases that contain sharded collections.
Examples
2.2. Database Commands 321
MongoDB Reference Manual, Release 2.6.4
Copy on the Same Host To copy from the same host, omit the fromhost eld.
The following command copies the test database to a new records database on the current mongod (page 555)
instance:
use admin
db.runCommand({
copydb: 1,
fromdb: "test",
todb: "records"
})
Copy from a Remote Host to the Current Host To copy from a remote host, include the fromhost eld.
The following command copies the test database from the remote host example.net to a newrecords database
on the current mongod (page 555) instance:
use admin
db.runCommand({
copydb: 1,
fromdb: "test",
todb: "records",
fromhost: "example.net"
})
Copy Databases from Remote mongod Instances that Enforce Authentication To copy from a remote host that
enforces authentication, include the fromhost, username, nonce and key elds.
The following command copies the test database from a remote host example.net that runs with
authorization to a new records database on the local mongod (page 555) instance. Because the
example.net has authorization enabled, the command includes the username, nonce and key elds:
use admin
db.runCommand({
copydb: 1,
fromdb: "test",
todb: "records",
fromhost: "example.net",
username: "reportingAdmin",
nonce: "<nonce>",
key: "<passwordhash>"
})
See also:
db.copyDatabase() (page 104)
clone (page 313) and db.cloneDatabase() (page 104)
http://docs.mongodb.org/manualcore/backups and http://docs.mongodb.org/manualcore/import-export
createIndexes New in version 2.6.
Denition
createIndexes
Builds one or more indexes on a collection. The createIndexes (page 322) command takes the following
form:
322 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.runCommand(
{
createIndexes: <collection>,
indexes: [
{
key: {
<key-value_pair>,
<key-value_pair>,
...
},
name: <index_name>,
<option1>,
<option2>,
...
},
{ ... },
{ ... }
]
}
)
The createIndexes (page 322) command takes the following elds:
eld string createIndexes The collection for which to create indexes.
eld array indexes Species the indexes to create. Each document in the array species a separate
index.
Each document in the indexes array can take the following elds:
eld document key Species the indexs elds. For each eld, specify a key-value pair in which the
key is the name of the eld to index and the value is either the index direction or index type.
If specifying direction, specify 1 for ascending or -1 for descending.
eld string name A name that uniquely identies the index.
eld string ns The namespace (i.e. <database>.<collection>) of the collection for which
to create the index. If you omit ns, MongoDB generates the namespace.
param Boolean background Builds the index in the background so that building an index does not
block other database activities. Specify true to build in the background. The default value is
false.
param Boolean unique Creates a unique index so that the collection will not accept insertion of
documents where the index key or keys match an existing value in the index. Specify true to
create a unique index. The default value is false.
The option is unavailable for hashed indexes.
param Boolean dropDups Creates a unique index on a eld that may have duplicates. MongoDB
indexes only the rst occurrence of a key and removes all documents from the collection that
contain subsequent occurrences of that key. Specify true to create unique index. The default
value is false.
The option is unavailable for hashed indexes.
Deprecated since version 2.6.
Warning: dropDups will delete data from your collection when building the index.
2.2. Database Commands 323
MongoDB Reference Manual, Release 2.6.4
param Boolean sparse If true, the index only references documents with the
specied eld. These indexes use less space but behave differently in
some situations (particularly sorts). The default value is false. See
http://docs.mongodb.org/manualcore/index-sparse for more informa-
tion.
Changed in version 2.6: 2dsphere indexes are sparse by default and ignore this option. For a
compound index that includes 2dsphere index key(s) along with keys of other types, only the
2dsphere index elds determine whether the index references a document.
2d, geoHaystack, and text indexes behave similarly to the 2dsphere indexes.
param integer expireAfterSeconds Species a value, in seconds, as a TTL to
control how long MongoDB retains documents in this collection. See
http://docs.mongodb.org/manualtutorial/expire-data for more infor-
mation on this functionality. This applies only to TTL indexes.
param index version v The index version number. The default index version depends on the version
of mongod (page 555) running when creating the index. Before version 2.0, the this value was
0; versions 2.0 and later use version 1, which provides a smaller and faster index format. Specify
a different index version only in unusual situations.
param document weights For text indexes, a document that contains eld and
weight pairs. The weight is an integer ranging from 1 to 99,999 and de-
notes the signicance of the eld relative to the other indexed elds in terms
of the score. You can specify weights for some or all the indexed elds. See
http://docs.mongodb.org/manualtutorial/control-results-of-text-search
to adjust the scores. The default value is 1.
param string default_language For text indexes, the language that deter-
mines the list of stop words and the rules for the stemmer and to-
kenizer. See text-search-languages for the available languages and
http://docs.mongodb.org/manualtutorial/specify-language-for-text-index
for more information and examples. The default value is english.
param string language_override For text indexes, the name of the eld, in the collections doc-
uments, that contains the override language for the document. The default value is language.
See specify-language-eld-text-index-example for an example.
param integer textIndexVersion For text indexes, the text index version number. Version can
be either 1 or 2.
In MongoDB 2.6, the default version is 2. MongoDB 2.4 can only support version 1.
New in version 2.6.
param integer 2dsphereIndexVersion For 2dsphere indexes, the 2dsphere index version
number. Version can be either 1 or 2.
In MongoDB 2.6, the default version is 2. MongoDB 2.4 can only support version 1.
New in version 2.6.
param integer bits For 2d indexes, the number of precision of the stored geohash value of the
location data.
The bits value ranges from 1 to 32 inclusive. The default value is 26.
param number min For 2d indexes, the lower inclusive boundary for the longitude and latitude
values. The default value is -180.0.
324 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
param number max For 2d indexes, the upper inclusive boundary for the longitude and latitude
values. The default value is 180.0.
param number bucketSize For geoHaystack indexes, specify the number of units within which
to group the location values; i.e. group in the same bucket those location values that are within
the specied number of units to each other.
The value must be greater than 0.
Considerations An index name, including the namespace, cannot be longer than the Index Name Length (page 659)
limit.
Behavior Non-background indexing operations block all other operations on a database. If you specify multiple
indexes to createIndexes (page 322), MongoDB builds the indexes serially.
If you create an index with one set of options and then issue createIndexes (page 322) with the same index elds
but different options, MongoDB will not change the options nor rebuild the index. To change index options, drop
the existing index with db.collection.dropIndex() (page 29) before running the new createIndexes
(page 322) with the new options.
Example The following command builds two indexes on the inventory collection of the products database:
db.getSiblingDB("products").runCommand(
{
createIndexes: "inventory",
indexes: [
{
key: {
item: 1,
manufacturer: 1,
model: 1
},
name: "item_manufacturer_model",
unique: true
},
{
key: {
item: 1,
supplier: 1,
model: 1
},
name: "item_supplier_model",
unique: true
}
]
}
)
When the indexes successfully nish building, MongoDB returns a results document that includes a status of "ok"
: 1.
Output The createIndexes (page 322) command returns a document that indicates the success of the operation.
The document contains some but not all of the following elds, depending on outcome:
createIndexes.createdCollectionAutomatically
If true, then the collection didnt exist and was created in the process of creating the index.
2.2. Database Commands 325
MongoDB Reference Manual, Release 2.6.4
createIndexes.numIndexesBefore
The number of indexes at the start of the command.
createIndexes.numIndexesAfter
The number of indexes at the end of the command.
createIndexes.ok
A value of 1 indicates the indexes are in place. A value of 0 indicates an error.
createIndexes.note
This note is returned if an existing index or indexes already exist. This indicates that the index was not created
or changed.
createIndexes.errmsg
Returns information about any errors.
createIndexes.code
The error code representing the type of error.
create
Denition
create
Explicitly creates a collection. create (page 326) has the following form:
{ create: <collection_name>,
capped: <true|false>,
autoIndexId: <true|false>,
size: <max_size>,
max: <max_documents>,
flags: <0|1>
}
create (page 326) has the following elds:
eld string create The name of the new collection.
eld Boolean capped To create a capped collection. specify true. If you specify true, you must
also set a maximum size in the size eld.
eld Boolean autoIndexId Specify false to disable the automatic creation of an index on the _id
eld. Before 2.2, the default value for autoIndexId was false.
eld integer size The maximum size for the capped collection. Once a capped collection reaches
its maximum size, MongoDB overwrites older old documents with new documents. The size
eld is required for capped collections.
eld integer max The maximum number of documents to keep in the capped collection. The size
limit takes precedence over this limit. If a capped collection reaches its maximum size before it
reaches the maximum number of documents, MongoDB removes old documents. If you use this
limit, ensure that the size limit is sufcient to contain the documents limit.
eld integer ags New in version 2.6.
Set to 0 to disable the usePowerOf2Sizes (page 314) allocation strategy for this col-
lection, or 1 to enable usePowerOf2Sizes (page 314). Defaults to 1 unless the
newCollectionsUsePowerOf2Sizes parameter is set to false.
For more information on the autoIndexId eld in versions before 2.2, see _id Fields and Indexes on Capped
Collections (page 739).
326 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The db.createCollection() (page 106) method wraps the create (page 326) command.
Considerations The create (page 326) command obtains a write lock on the affected database and will block
other operations until it has completed. The write lock for this operation is typically short lived. However, allocations
for large capped collections may take longer.
Example To create a capped collection limited to 64 kilobytes, issue the command in the following form:
db.runCommand( { create: "collection", capped: true, size: 64
*
1024 } )
dropDatabase
dropDatabase
The dropDatabase (page 327) command drops a database, deleting the associated data les.
dropDatabase (page 327) operates on the current database.
In the shell issue the use <database> command, replacing <database> with the name of the database
you wish to delete. Then use the following command form:
{ dropDatabase: 1 }
The mongo (page 580) shell also provides the following equivalent helper method:
db.dropDatabase();
Warning: This command obtains a global write lock and will block other operations until it has completed.
dropIndexes
dropIndexes
The dropIndexes (page 327) command drops one or all indexes from the current collection. To drop all
indexes, issue the command like so:
{ dropIndexes: "collection", index: "
*
" }
To drop a single, issue the command by specifying the name of the index you want to drop. For example, to
drop the index named age_1, use the following command:
{ dropIndexes: "collection", index: "age_1" }
The shell provides a useful command helper. Heres the equivalent command:
db.collection.dropIndex("age_1");
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed.
drop
drop
The drop (page 327) command removes an entire collection from a database. The command has following
syntax:
{ drop: <collection_name> }
2.2. Database Commands 327
MongoDB Reference Manual, Release 2.6.4
The mongo (page 580) shell provides the equivalent helper method db.collection.drop() (page 28).
This command also removes any indexes associated with the dropped collection.
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed.
lemd5
filemd5
The filemd5 (page 328) command returns the md5 hashes for a single le stored using the GridFS speci-
cation. Client libraries use this command to verify that les are correctly written to MongoDB. The command
takes the files_id of the le in question and the name of the GridFS root collection as arguments. For
example:
{ filemd5: ObjectId("4f1f10e37671b50e4ecd2776"), root: "fs" }
MongoDB computes the filemd5 using all data in the GridFS le object pulled sequentially from each chunk
in the chunks collection.
fsync
Denition
fsync
Forces the mongod (page 555) process to ush all pending writes from the storage layer to disk. Optionally,
you can use fsync (page 328) to lock the mongod (page 555) instance and block write operations for the
purpose of capturing backups.
As applications write data, MongoDB records the data in the storage layer and then writes the data to disk within
the syncPeriodSecs interval, which is 60 seconds by default. Run fsync (page 328) when you want to
ush writes to disk ahead of that interval.
The fsync (page 328) command has the following syntax:
{ fsync: 1, async: <Boolean>, lock: <Boolean> }
The fsync (page 328) command has the following elds:
eld integer fsync Enter 1 to apply fsync (page 328).
eld Boolean async Runs fsync (page 328) asynchronously. By default, the fsync (page 328)
operation is synchronous.
eld Boolean lock Locks mongod (page 555) instance and blocks all write operations.
Behavior An fsync (page 328) lock is only possible on individual mongod (page 555) instances
of a sharded cluster, not on the entire cluster. To backup an entire sharded cluster, please see
http://docs.mongodb.org/manualadministration/backup-sharded-clusters for more infor-
mation.
If your mongod (page 555) has journaling enabled, consider using another method to create a back up of the data set.
After fsync (page 328), with lock, runs on a mongod (page 555), all write operations will block until a subsequent
unlock. Read operations may also block. As a result, fsync (page 328), with lock, is not a reliable mechanism for
making a mongod (page 555) instance operate in a read-only mode.
Important: Blocked read operations prevent verication of authentication. Such reads are necessary to establish new
328 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
connections to a mongod (page 555) that enforces authorization checks.
Warning: When calling fsync (page 328) with lock, ensure that the connection remains open to allow a subse-
quent call to db.fsyncUnlock() (page 115).
Closing the connection may make it difcult to release the lock.
Examples
Run Asynchronously The fsync (page 328) operation is synchronous by default To run fsync (page 328) asyn-
chronously, use the async eld set to true:
{ fsync: 1, async: true }
The operation returns immediately. To view the status of the fsync (page 328) operation, check the output of
db.currentOp() (page 107).
Lock mongod Instance The primary use of fsync (page 328) is to lock the mongod (page 555) instance in order
to back up the les withing mongod (page 555)s dbPath. The operation ushes all data to the storage layer and
blocks all write operations until you unlock the mongod (page 555) instance.
To lock the database, use the lock eld set to true:
{ fsync: 1, lock: true }
You may continue to perform read operations on a mongod (page 555) instance that has a fsync (page 328) lock.
However, after the rst write operation all subsequent read operations wait until you unlock the mongod (page 555)
instance.
Unlock mongod Instance To unlock the mongod (page 555), use db.fsyncUnlock() (page 115):
db.fsyncUnlock();
Check Lock Status To check the state of the fsync lock, use db.currentOp() (page 107). Use the following
JavaScript function in the shell to test if mongod (page 555) instance is currently locked:
serverIsLocked = function () {
var co = db.currentOp();
if (co && co.fsyncLock) {
return true;
}
return false;
}
After loading this function into your mongo (page 580) shell session call it, with the following syntax:
serverIsLocked()
This function will return true if the mongod (page 555) instance is currently locked and false if the mongod
(page 555) is not locked.
2.2. Database Commands 329
MongoDB Reference Manual, Release 2.6.4
getParameter
getParameter
getParameter (page 330) is an administrative command for retrieving the value of options normally set on
the command line. Issue commands against the admin database as follows:
{ getParameter: 1, <option>: 1 }
The values specied for getParameter and <option> do not affect the output. The command works with
the following options:
quiet
notablescan
logLevel
syncdelay
See also:
setParameter (page 334) for more about these parameters.
logRotate
logRotate
The logRotate (page 330) command is an administrative command that allows you to rotate the Mon-
goDB logs to prevent a single logle from consuming too much disk space. You must issue the logRotate
(page 330) command against the admin database in the form:
{ logRotate: 1 }
Note: Your mongod (page 555) instance needs to be running with the --logpath [file] option.
You may also rotate the logs by sending a SIGUSR1 signal to the mongod (page 555) process. If your mongod
(page 555) has a process ID of 2200, heres how to send the signal on Linux:
kill -SIGUSR1 2200
logRotate (page 330) renames the existing log le by appending the current timestamp to the lename. The
appended timestamp has the following form:
<YYYY>-<mm>-<DD>T<HH>-<MM>-<SS>
Then logRotate (page 330) creates a new log le with the same name as originally specied by the
systemLog.path setting to mongod (page 555) or mongos (page 571).
Note: New in version 2.0.3: The logRotate (page 330) command is available to mongod (page 555)
instances running on Windows systems with MongoDB release 2.0.3 and higher.
reIndex
reIndex
The reIndex (page 330) command drops all indexes on a collection and recreates them. This operation may be
expensive for collections that have a large amount of data and/or a large number of indexes. Use the following
syntax:
{ reIndex: "collection" }
330 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Normally, MongoDB compacts indexes during routine updates. For most users, the reIndex (page 330)
command is unnecessary. However, it may be worth running if the collection size has changed signicantly or
if the indexes are consuming a disproportionate amount of disk space.
Call reIndex (page 330) using the following form:
db.collection.reIndex();
Note: For replica sets, reIndex (page 330) will not propagate from the primary to secondaries. reIndex
(page 330) will only affect a single mongod (page 555) instance.
Important: reIndex (page 330) will rebuild indexes in the background if the index was originally specied
with this option. However, reIndex (page 330) will rebuild the _id index in the foreground, which takes the
databases write lock.
See
http://docs.mongodb.org/manualcore/index-creation for more information on the behavior of in-
dexing operations in MongoDB.
renameCollection
Denition
renameCollection
Changes the name of an existing collection. Specify collections to renameCollection (page 331) in the
form of a complete namespace, which includes the database name. Issue the renameCollection (page 331)
command against the admin database. The command takes the following form:
{ renameCollection: "<source_namespace>", to: "<target_namespace>", dropTarget: <true|false> }
The command contains the following elds:
eld string renameCollection The namespace of the collection to rename. The namespace is a
combination of the database name and the name of the collection.
eld string to The new namespace of the collection. If the new namespace species a different
database, the renameCollection (page 331) command copies the collection to the new
database and drops the source collection.
eld boolean dropTarget If true, mongod (page 555) will drop the target of
renameCollection (page 331) prior to renaming the collection.
renameCollection (page 331) is suitable for production environments; however:
renameCollection (page 331) blocks all database activity for the duration of the operation.
renameCollection (page 331) is not compatible with sharded collections.
Warning: renameCollection (page 331) fails if target is the name of an existing collection and
you do not specify dropTarget: true.
If the renameCollection (page 331) operation does not complete the target collection and indexes
will not be usable and will require manual intervention to clean up.
2.2. Database Commands 331
MongoDB Reference Manual, Release 2.6.4
Exceptions
exception 10026 Raised if the source namespace does not exist.
exception 10027 Raised if the target namespace exists and dropTarget is either false or unspec-
ied.
exception 15967 Raised if the target namespace is an invalid collection name.
Shell Helper The shell helper db.collection.renameCollection() (page 67) provides a simpler inter-
face to using this command within a database. The following is equivalent to the previous example:
db.source-namespace.renameCollection( "target" )
Warning: You cannot use renameCollection (page 331) with sharded collections.
Warning: This command obtains a global write lock and will block other operations until it has completed.
repairDatabase
Denition
repairDatabase
Checks and repairs errors and inconsistencies in data storage. repairDatabase (page 332) is analogous to
a fsck command for le systems. Run the repairDatabase (page 332) command to ensure data integrity
after the system experiences an unexpected system restart or crash, if:
1.The mongod (page 555) instance is not running with journaling enabled.
When using journaling, there is almost never any need to run repairDatabase (page 332). In the event
of an unclean shutdown, the server will be able to restore the data les to a pristine state automatically.
2.There are no other intact replica set members with a complete data set.
Warning: During normal operations, only use the repairDatabase (page 332) command
and wrappers including db.repairDatabase() (page 123) in the mongo (page 580) shell and
mongod --repair, to compact database les and/or reclaim disk space. Be aware that these oper-
ations remove and do not save any corrupt data during the repair process.
If you are trying to repair a replica set member, and you have access to an intact copy of your data (e.g.
a recent backup or an intact member of the replica set), you should restore from that intact copy, and
not use repairDatabase (page 332).
repairDatabase (page 332) takes the following form:
{ repairDatabase: 1 }
repairDatabase (page 332) has the following elds:
eld boolean preserveClonedFilesOnFailure When true, repairDatabase will not delete
temporary les in the backup directory on error, and all new les are created with the backup
instead of _tmp directory prex. By default repairDatabase does not delete temporary
les, and uses the _tmp naming prex for new les.
eld boolean backupOriginalFiles When true, repairDatabase moves old database les to
the backup directory instead of deleting them before moving new les into place. New les are
332 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
created with the backup instead of _tmp directory prex. By default, repairDatabase
leaves temporary les unchanged, and uses the _tmp naming prex for new les.
You can explicitly set the options as follows:
{ repairDatabase: 1,
preserveClonedFilesOnFailure: <boolean>,
backupOriginalFiles: <boolean> }
Warning: This command obtains a global write lock and will block other operations until it has completed.
Note: repairDatabase (page 332) requires free disk space equal to the size of your current data set plus
2 gigabytes. If the volume that holds dbpath lacks sufcient space, you can mount a separate volume and
use that for the repair. When mounting a separate volume for repairDatabase (page 332) you must run
repairDatabase (page 332) from the command line and use the --repairpath switch to specify the
folder in which to store temporary repair les.
See mongod --repair and mongodump --repair for information on these related options.
Behavior Changed in version 2.6: The repairDatabase (page 332) command is now available for secondary as
well as primary members of replica sets.
The repairDatabase (page 332) command compacts all collections in the database. It is identical to running the
compact (page 316) command on each collection individually.
repairDatabase (page 332) reduces the total size of the data les on disk. It also recreates all indexes in the
database.
The time requirement for repairDatabase (page 332) depends on the size of the data set.
You may invoke repairDatabase (page 332) from multiple contexts:
Use the mongo (page 580) shell to run the command, as above.
Use the db.repairDatabase() (page 123) in the mongo (page 580) shell.
Run mongod (page 555) directly from your systems shell. Make sure that mongod (page 555) isnt already
running, and that you invoke mongod (page 555) as a user that has access to MongoDBs data les. Run as:
mongod --repair
To add a repair path:
mongod --repair --repairpath /opt/vol2/data
Note: mongod --repair will fail if your database is not a master or primary. In most cases, you should
recover a corrupt secondary using the data from an existing intact node. To run repair on a secondary/slave
restart the instance in standalone mode without the --replSet or --slave options.
Example
{ repairDatabase: 1 }
Using repairDatabase to Reclaim Disk Space You should not use repairDatabase (page 332) for data
recovery unless you have no other option.
2.2. Database Commands 333
MongoDB Reference Manual, Release 2.6.4
However, if you trust that there is no corruption and you have enough free space, then repairDatabase (page 332)
is the appropriate and the only way to reclaim disk space.
setParameter
setParameter
setParameter (page 334) is an administrative command for modifying options normally set on the command
line. You must issue the setParameter (page 334) command against the admin database in the form:
{ setParameter: 1, <option>: <value> }
Replace the <option> with one of the supported setParameter (page 334) options:
journalCommitInterval
logLevel
logUserIds
notablescan
quiet
replApplyBatchSize
replIndexPrefetch
syncdelay
traceExceptions
textSearchEnabled
sslMode
clusterAuthMode
userCacheInvalidationIntervalSecs
shutdown
shutdown
The shutdown (page 334) command cleans up all database resources and then terminates the process. You
must issue the shutdown (page 334) command against the admin database in the form:
{ shutdown: 1 }
Note: Run the shutdown (page 334) against the admin database. When using shutdown (page 334), the
connection must originate from localhost or use an authenticated connection.
If the node youre trying to shut down is a replica set primary, then the command will succeed only if there
exists a secondary node whose oplog data is within 10 seconds of the primary. You can override this protection
using the force option:
{ shutdown: 1, force: true }
Alternatively, the shutdown (page 334) command also supports a timeoutSecs argument which allows
you to specify a number of seconds to wait for other members of the replica set to catch up:
{ shutdown: 1, timeoutSecs: 60 }
The equivalent mongo (page 580) shell helper syntax looks like this:
334 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.shutdownServer({timeoutSecs: 60});
touch
touch
New in version 2.2.
The touch (page 335) command loads data from the data storage layer into memory. touch (page 335) can
load the data (i.e. documents) indexes or both documents and indexes. Use this command to ensure that a
collection, and/or its indexes, are in memory before another operation. By loading the collection or indexes
into memory, mongod (page 555) will ideally be able to perform subsequent operations more efciently. The
touch (page 335) command has the following prototypical form:
{ touch: [collection], data: [boolean], index: [boolean] }
By default, data and index are false, and touch (page 335) will perform no operation. For example, to load
both the data and the index for a collection named records, you would use the following command in the
mongo (page 580) shell:
db.runCommand({ touch: "records", data: true, index: true })
touch (page 335) will not block read and write operations on a mongod (page 555), and can run on secondary
members of replica sets.
Note: Using touch (page 335) to control or tweak what a mongod (page 555) stores in memory may displace
other records data in memory and hinder performance. Use with caution in production systems.
Warning: If you run touch (page 335) on a secondary, the secondary will enter a RECOVERING state
to prevent clients from sending read operations during the touch (page 335) operation. When touch
(page 335) nishes the secondary will automatically return to SECONDARY state. See state (page 291)
for more information on replica set member states.
2.2. Database Commands 335
MongoDB Reference Manual, Release 2.6.4
Diagnostic Commands
Diagnostic Commands
Name Description
availableQueryOptions
(page 336)
Internal command that reports on the capabilities of the current MongoDB
instance.
buildInfo (page 336) Displays statistics about the MongoDB build.
collStats (page 338) Reports storage utilization statics for a specied collection.
connPoolStats
(page 340)
Reports statistics on the outgoing connections from this MongoDB instance to
other MongoDB instances in the deployment.
cursorInfo (page 342) Deprecated. Reports statistics on active cursors.
dataSize (page 342) Returns the data size for a range of data. For internal use.
dbHash (page 342) Internal command to support sharding.
dbStats (page 342) Reports storage utilization statistics for the specied database.
diagLogging (page 344) Provides a diagnostic logging. For internal use.
driverOIDTest
(page 344)
Internal command that converts an ObjectId to a string to support tests.
features (page 344) Reports on features available in the current MongoDB instance.
getCmdLineOpts
(page 344)
Returns a document with the run-time arguments to the MongoDB instance and
their parsed options.
getLog (page 345) Returns recent log messages.
hostInfo (page 345) Returns data that reects the underlying host system.
indexStats (page 347) Experimental command that collects and aggregates statistics on all indexes.
isSelf Internal command to support testing.
listCommands
(page 352)
Lists all database commands provided by the current mongod (page 555) instance.
listDatabases
(page 352)
Returns a document that lists all databases and returns basic database statistics.
netstat (page 353) Internal command that reports on intra-deployment connectivity. Only available
for mongos (page 571) instances.
ping (page 353) Internal command that tests intra-deployment connectivity.
profile (page 353) Interface for the database proler.
serverStatus
(page 354)
Returns a collection metrics on instance-wide resource utilization and status.
shardConnPoolStats
(page 371)
Reports statistics on a mongos (page 571)s connection pool for client operations
against shards.
top (page 373) Returns raw usage statistics for each database in the mongod (page 555) instance.
validate (page 374) Internal command that scans for a collections data and indexes for correctness.
whatsmyuri (page 377) Internal command that returns information on the current client.
availableQueryOptions
availableQueryOptions
availableQueryOptions (page 336) is an internal command that is only available on mongos (page 571)
instances.
buildInfo
buildInfo
The buildInfo (page 336) command is an administrative command which returns a build summary for the
current mongod (page 555). buildInfo (page 336) has the following prototype form:
336 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ buildInfo: 1 }
In the mongo (page 580) shell, call buildInfo (page 336) in the following form:
db.runCommand( { buildInfo: 1 } )
Example
The output document of buildInfo (page 336) has the following form:
{
"version" : "<string>",
"gitVersion" : "<string>",
"sysInfo" : "<string>",
"loaderFlags" : "<string>",
"compilerFlags" : "<string>",
"allocator" : "<string>",
"versionArray" : [ <num>, <num>, <...> ],
"javascriptEngine" : "<string>",
"bits" : <num>,
"debug" : <boolean>,
"maxBsonObjectSize" : <num>,
"ok" : <num>
}
Consider the following documentation of the output of buildInfo (page 336):
buildInfo
The document returned by the buildInfo (page 336) command.
buildInfo.gitVersion
The commit identier that identies the state of the code used to build the mongod (page 555).
buildInfo.sysInfo
A string that holds information about the operating system, hostname, kernel, date, and Boost version used
to compile the mongod (page 555).
buildInfo.loaderFlags
The ags passed to the loader that loads the mongod (page 555).
buildInfo.compilerFlags
The ags passed to the compiler that builds the mongod (page 555) binary.
buildInfo.allocator
Changed in version 2.2.
The memory allocator that mongod (page 555) uses. By default this is tcmalloc after version 2.2, and
system before 2.2.
buildInfo.versionArray
An array that conveys version information about the mongod (page 555) instance. See version for a
more readable version of this string.
buildInfo.javascriptEngine
Changed in version 2.4.
A string that reports the JavaScript engine used in the mongod (page 555) instance. By default, this is V8
after version 2.4, and SpiderMonkey before 2.4.
buildInfo.bits
A number that reects the target processor architecture of the mongod (page 555) binary.
2.2. Database Commands 337
MongoDB Reference Manual, Release 2.6.4
buildInfo.debug
A boolean. true when built with debugging options.
buildInfo.maxBsonObjectSize
A number that reports the Maximum BSON Document Size (page 658).
collStats
Denition
collStats
The collStats (page 338) command returns a variety of storage statistics for a given collection. Use the
following syntax:
{ collStats: "collection" , scale : 1024 }
Specify the collection you want statistics for, and use the scale argument to scale the output. The above
example will display values in kilobytes.
Examine the following example output, which uses the db.collection.stats() (page 69) helper in the
mongo (page 580) shell.
> db.users.stats()
{
"ns" : "app.users", // namespace
"count" : 9, // number of documents
"size" : 432, // collection size in bytes
"avgObjSize" : 48, // average object size in bytes
"storageSize" : 3840, // (pre)allocated space for the collection in bytes
"numExtents" : 1, // number of extents (contiguously allocated chunks of datafile space)
"nindexes" : 2, // number of indexes
"lastExtentSize" : 3840, // size of the most recently created extent in bytes
"paddingFactor" : 1, // padding can speed up updates if documents grow
"flags" : 1,
"totalIndexSize" : 16384, // total index size in bytes
"indexSizes" : { // size of specific indexes in bytes
"_id_" : 8192,
"username" : 8192
},
"ok" : 1
}
Note: The scale factor rounds values to whole numbers. This can produce unpredictable and unexpected results
in some situations.
Output
collStats.ns
The namespace of the current collection, which follows the format [database].[collection].
collStats.count
The number of objects or documents in this collection.
collStats.size
The total size of all records in a collection. This value does not include the record header, which is 16 bytes per
record, but does include the records padding. Additionally size (page 338) does not include the size of any
indexes associated with the collection, which the totalIndexSize (page 339) eld reports.
The scale argument affects this value.
338 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
collStats.avgObjSize
The average size of an object in the collection. The scale argument affects this value.
collStats.storageSize
The total amount of storage allocated to this collection for document storage. The scale argument affects this
value. The storageSize (page 339) does not decrease as you remove or shrink documents.
collStats.numExtents
The total number of contiguously allocated data le regions.
collStats.nindexes
The number of indexes on the collection. All collections have at least one index on the _id eld.
Changed in version 2.2: Before 2.2, capped collections did not necessarily have an index on the _id eld, and
some capped collections created with pre-2.2 versions of mongod (page 555) may not have an _id index.
collStats.lastExtentSize
The size of the last extent allocated. The scale argument affects this value.
collStats.paddingFactor
The amount of space added to the end of each document at insert time. The document padding provides a small
amount of extra space on disk to allow a document to grow slightly without needing to move the document.
mongod (page 555) automatically calculates this padding factor
collStats.flags
Changed in version 2.2: Removed in version 2.2 and replaced with the userFlags (page 339) and
systemFlags (page 339) elds.
Indicates the number of ags on the current collection. In version 2.0, the only ag notes the existence of an
index on the _id eld.
collStats.systemFlags
New in version 2.2.
Reports the ags on this collection that reect internal server options. Typically this value is 1 and reects the
existence of an index on the _id eld.
collStats.userFlags
New in version 2.2.
Reports the ags on this collection set by the user. In version 2.2 the only user ag is usePowerOf2Sizes
(page 314). If usePowerOf2Sizes (page 314) is enabled, userFlags (page 339) will be set to 1, otherwise
userFlags (page 339) will be 0.
See the collMod (page 314) command for more information on setting user ags and usePowerOf2Sizes
(page 314).
collStats.totalIndexSize
The total size of all indexes. The scale argument affects this value.
collStats.indexSizes
This eld species the key and size of every existing index on the collection. The scale argument affects this
value.
Example The following is an example of db.collection.stats() (page 69) and collStats (page 338)
output:
{
"ns" : "<database>.<collection>",
"count" : <number>,
"size" : <number>,
2.2. Database Commands 339
MongoDB Reference Manual, Release 2.6.4
"avgObjSize" : <number>,
"storageSize" : <number>,
"numExtents" : <number>,
"nindexes" : <number>,
"lastExtentSize" : <number>,
"paddingFactor" : <number>,
"systemFlags" : <bit>,
"userFlags" : <bit>,
"totalIndexSize" : <number>,
"indexSizes" : {
"_id_" : <number>,
"a_1" : <number>
},
"ok" : 1
}
connPoolStats
Denition
connPoolStats
Note: connPoolStats (page 340) only returns meaningful results for mongos (page 571) instances and
for mongod (page 555) instances in sharded clusters.
The command connPoolStats (page 340) returns information regarding the number of open connections to
the current database instance, including client connections and server-to-server connections for replication and
clustering. The command takes the following form:
{ connPoolStats: 1 }
The value of the argument (i.e. 1 ) does not affect the output of the command.
Note: connPoolStats (page 340) only returns meaningful results for mongos (page 571) instances and
for mongod (page 555) instances in sharded clusters.
Output
connPoolStats.hosts
The sub-documents of the hosts (page 340) document report connections between the mongos (page 571) or
mongod (page 555) instance and each component mongod (page 555) of the sharded cluster.
connPoolStats.hosts.[host].available
available (page 340) reports the total number of connections that the mongos (page 571) or mongod
(page 555) could use to connect to this mongod (page 555).
connPoolStats.hosts.[host].created
created (page 340) reports the number of connections that this mongos (page 571) or mongod
(page 555) has ever created for this host.
connPoolStats.replicaSets
replicaSets (page 340) is a document that contains replica set information for the sharded cluster.
connPoolStats.replicaSets.shard
The shard (page 340) document reports on each shard within the sharded cluster
340 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
connPoolStats.replicaSets.[shard].host
The host (page 340) eld holds an array of document that reports on each host within the shard in the
replica set.
These values derive from the replica set status (page 289) values.
connPoolStats.replicaSets.[shard].host[n].addr
addr (page 341) reports the address for the host in the sharded cluster in the format of
[hostname]:[port].
connPoolStats.replicaSets.[shard].host[n].ok
ok (page 341) reports false when:
the mongos (page 571) or mongod (page 555) cannot connect to instance.
the mongos (page 571) or mongod (page 555) received a connection exception or error.
This eld is for internal use.
connPoolStats.replicaSets.[shard].host[n].ismaster
ismaster (page 341) reports true if this host (page 340) is the primary member of the replica
set.
connPoolStats.replicaSets.[shard].host[n].hidden
hidden (page 341) reports true if this host (page 340) is a hidden member of the replica set.
connPoolStats.replicaSets.[shard].host[n].secondary
secondary (page 341) reports true if this host (page 340) is a secondary member of the replica
set.
connPoolStats.replicaSets.[shard].host[n].pingTimeMillis
pingTimeMillis (page 341) reports the ping time in milliseconds from the mongos (page 571)
or mongod (page 555) to this host (page 340).
connPoolStats.replicaSets.[shard].host[n].tags
New in version 2.2.
tags (page 341) reports the tags, if this member of the set has tags congured.
connPoolStats.replicaSets.[shard].master
master (page 341) reports the ordinal identier of the host in the host (page 340) array that is the
primary of the replica set.
connPoolStats.replicaSets.[shard].nextSlave
Deprecated since version 2.2.
nextSlave (page 341) reports the secondary member that the mongos (page 571) will use to service
the next request for this replica set.
connPoolStats.createdByType
createdByType (page 341) document reports the number of each type of connection that mongos (page 571)
or mongod (page 555) has created in all connection pools.
mongos (page 571) connect to mongod (page 555) instances using one of three types of connections. The
following sub-document reports the total number of connections by type.
connPoolStats.createdByType.master
master (page 341) reports the total number of connections to the primary member in each cluster.
connPoolStats.createdByType.set
set (page 341) reports the total number of connections to a replica set member.
connPoolStats.createdByType.sync
sync (page 341) reports the total number of cong database connections.
2.2. Database Commands 341
MongoDB Reference Manual, Release 2.6.4
connPoolStats.totalAvailable
totalAvailable (page 341) reports the running total of connections from the mongos (page 571) or
mongod (page 555) to all mongod (page 555) instances in the sharded cluster available for use.
connPoolStats.totalCreated
totalCreated (page 342) reports the total number of connections ever created from the mongos (page 571)
or mongod (page 555) to all mongod (page 555) instances in the sharded cluster.
connPoolStats.numDBClientConnection
numDBClientConnection (page 342) reports the total number of connections fromthe mongos (page 571)
or mongod (page 555) to all of the mongod (page 555) instances in the sharded cluster.
connPoolStats.numAScopedConnection
numAScopedConnection (page 342) reports the number of exception safe connections created from
mongos (page 571) or mongod (page 555) to all mongod (page 555) in the sharded cluster. The mongos
(page 571) or mongod (page 555) releases these connections after receiving a socket exception from the
mongod (page 555).
cursorInfo Deprecated since version 2.6: Use the serverStatus (page 354) command to return the
serverStatus.metrics.cursor (page 371) information instead.
cursorInfo
The cursorInfo (page 342) command returns information about current cursor allotment and use. Use the
following form:
{ cursorInfo: 1 }
The value (e.g. 1 above) does not affect the output of the command.
cursorInfo (page 342) returns the total number of open cursors (totalOpen), the size of client cursors
in current use (clientCursors_size), and the number of timed out cursors since the last server restart
(timedOut).
dataSize
dataSize
The dataSize (page 342) command returns the data size for a set of data within a certain range:
{ dataSize: "database.collection", keyPattern: { field: 1 }, min: { field: 10 }, max: { field: 100 } }
This will return a document that contains the size of all matching documents. Replace
database.collection value with database and collection from your deployment. The keyPattern,
min, and max parameters are options.
The amount of time required to return dataSize (page 342) depends on the amount of data in the collection.
dbHash
dbHash
dbHash (page 342) is a command that supports cong servers and is not part of the stable client facing API.
dbStats
Denition
dbStats
The dbStats (page 342) command returns storage statistics for a given database. The command takes the
following syntax:
342 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ dbStats: 1, scale: 1 }
The values of the options above do not affect the output of the command. The scale option allows you to
specify how to scale byte values. For example, a scale value of 1024 will display the results in kilobytes
rather than in bytes:
{ dbStats: 1, scale: 1024 }
Note: Because scaling rounds values to whole numbers, scaling may return unlikely or unexpected results.
The time required to run the command depends on the total size of the database. Because the command must
touch all data les, the command may take several seconds to run.
In the mongo (page 580) shell, the db.stats() (page 126) function provides a wrapper around dbStats
(page 342).
Output
dbStats.db
Contains the name of the database.
dbStats.collections
Contains a count of the number of collections in that database.
dbStats.objects
Contains a count of the number of objects (i.e. documents) in the database across all collections.
dbStats.avgObjSize
The average size of each document in bytes. This is the dataSize (page 343) divided by the number of
documents.
dbStats.dataSize
The total size in bytes of the data held in this database including the padding factor. The scale argument
affects this value. The dataSize (page 343) will not decrease when documents shrink, but will decrease when
you remove documents.
dbStats.storageSize
The total amount of space in bytes allocated to collections in this database for document storage. The scale
argument affects this value. The storageSize (page 343) does not decrease as you remove or shrink docu-
ments.
dbStats.numExtents
Contains a count of the number of extents in the database across all collections.
dbStats.indexes
Contains a count of the total number of indexes across all collections in the database.
dbStats.indexSize
The total size in bytes of all indexes created on this database. The scale arguments affects this value.
dbStats.fileSize
The total size in bytes of the data les that hold the database. This value includes preallocated space and the
padding factor. The value of fileSize (page 343) only reects the size of the data les for the database and
not the namespace le.
The scale argument affects this value.
dbStats.nsSizeMB
The total size of the namespace les (i.e. that end with .ns) for this database. You cannot change the size of
the namespace le after creating a database, but you can change the default size for all new namespace les with
the nsSize runtime option.
2.2. Database Commands 343
MongoDB Reference Manual, Release 2.6.4
See also:
The nsSize option, and Maximum Namespace File Size (page 658)
dbStats.dataFileVersion
New in version 2.4.
Document that contains information about the on-disk format of the data les for the database.
dbStats.dataFileVersion.major
New in version 2.4.
The major version number for the on-disk format of the data les for the database.
dbStats.dataFileVersion.minor
New in version 2.4.
The minor version number for the on-disk format of the data les for the database.
diagLogging
diagLogging
diagLogging (page 344) is a command that captures additional data for diagnostic purposes and is not part
of the stable client facing API.
diaglogging obtains a write lock on the affected database and will block other operations until it completes.
driverOIDTest
driverOIDTest
driverOIDTest (page 344) is an internal command.
features
features
features (page 344) is an internal command that returns the build-level feature settings.
getCmdLineOpts
getCmdLineOpts
The getCmdLineOpts (page 344) command returns a document containing command line options used to
start the given mongod (page 555) or mongos (page 571):
{ getCmdLineOpts: 1 }
This command returns a document with two elds, argv and parsed. The argv eld contains an array with
each item from the command string used to invoke mongod (page 555) or mongos (page 571). The document
in the parsed eld includes all runtime options, including those parsed from the command line and those
specied in the conguration le, if specied.
Consider the following example output of getCmdLineOpts (page 344):
{
"argv" : [
"/usr/bin/mongod",
"--config",
"/etc/mongodb.conf",
"--fork"
],
"parsed" : {
"bind_ip" : "127.0.0.1",
"config" : "/etc/mongodb/mongodb.conf",
344 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"dbpath" : "/srv/mongodb",
"fork" : true,
"logappend" : "true",
"logpath" : "/var/log/mongodb/mongod.log",
"quiet" : "true"
},
"ok" : 1
}
getLog
getLog
The getLog (page 345) command returns a document with a log array that contains recent messages from the
mongod (page 555) process log. The getLog (page 345) command has the following syntax:
{ getLog: <log> }
Replace <log> with one of the following values:
global - returns the combined output of all recent log entries.
rs - if the mongod (page 555) is part of a replica set, getLog (page 345) will return recent notices
related to replica set activity.
startupWarnings - will return logs that may contain errors or warnings from MongoDBs log from
when the current process started. If mongod (page 555) started without warnings, this lter may return an
empty array.
You may also specify an asterisk (e.g.
*
) as the <log> value to return a list of available log lters. The
following interaction from the mongo (page 580) shell connected to a replica set:
db.adminCommand({getLog: "
*
" })
{ "names" : [ "global", "rs", "startupWarnings" ], "ok" : 1 }
getLog (page 345) returns events from a RAM cache of the mongod (page 555) events and does not read log
data from the log le.
hostInfo
hostInfo
New in version 2.2.
Returns A document with information about the underlying system that the mongod (page 555) or
mongos (page 571) runs on. Some of the returned elds are only included on some platforms.
You must run the hostInfo (page 345) command, which takes no arguments, against the admin database.
Consider the following invocations of hostInfo (page 345):
db.hostInfo()
db.adminCommand( { "hostInfo" : 1 } )
In the mongo (page 580) shell you can use db.hostInfo() (page 119) as a helper to access hostInfo
(page 345). The output of hostInfo (page 345) on a Linux system will resemble the following:
{
"system" : {
"currentTime" : ISODate("<timestamp>"),
"hostname" : "<hostname>",
"cpuAddrSize" : <number>,
"memSizeMB" : <number>,
2.2. Database Commands 345
MongoDB Reference Manual, Release 2.6.4
"numCores" : <number>,
"cpuArch" : "<identifier>",
"numaEnabled" : <boolean>
},
"os" : {
"type" : "<string>",
"name" : "<string>",
"version" : "<string>"
},
"extra" : {
"versionString" : "<string>",
"libcVersion" : "<string>",
"kernelVersion" : "<string>",
"cpuFrequencyMHz" : "<string>",
"cpuFeatures" : "<string>",
"pageSize" : <number>,
"numPages" : <number>,
"maxOpenFiles" : <number>
},
"ok" : <return>
}
Consider the following documentation of these elds:
hostInfo
The document returned by the hostInfo (page 345).
hostInfo.system
A sub-document about the underlying environment of the system running the mongod (page 555) or
mongos (page 571)
hostInfo.system.currentTime
A time stamp of the current system time.
hostInfo.system.hostname
The system name, which should correspond to the output of hostname -f on Linux systems.
hostInfo.system.cpuAddrSize
A number reecting the architecture of the system. Either 32 or 64.
hostInfo.system.memSizeMB
The total amount of system memory (RAM) in megabytes.
hostInfo.system.numCores
The total number of available logical processor cores.
hostInfo.system.cpuArch
A string that represents the system architecture. Either x86 or x86_64.
hostInfo.system.numaEnabled
A boolean value. false if NUMA is interleaved (i.e. disabled), otherwise true.
hostInfo.os
A sub-document that contains information about the operating system running the mongod (page 555)
and mongos (page 571).
hostInfo.os.type
A string representing the type of operating system, such as Linux or Windows.
hostInfo.os.name
If available, returns a display name for the operating system.
346 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
hostInfo.os.version
If available, returns the name of the distribution or operating system.
hostInfo.extra
A sub-document with extra information about the operating system and the underlying hardware. The
content of the extra (page 347) sub-document depends on the operating system.
hostInfo.extra.versionString
A complete string of the operating system version and identication. On Linux and OS X systems, this
contains output similar to uname -a.
hostInfo.extra.libcVersion
The release of the system libc.
libcVersion (page 347) only appears on Linux systems.
hostInfo.extra.kernelVersion
The release of the Linux kernel in current use.
kernelVersion (page 347) only appears on Linux systems.
hostInfo.extra.alwaysFullSync
alwaysFullSync (page 347) only appears on OS X systems.
hostInfo.extra.nfsAsync
nfsAsync (page 347) only appears on OS X systems.
hostInfo.extra.cpuFrequencyMHz
Reports the clock speed of the systems processor in megahertz.
hostInfo.extra.cpuFeatures
Reports the processor feature ags. On Linux systems this the same information that
http://docs.mongodb.org/manualproc/cpuinfo includes in the flags elds.
hostInfo.extra.pageSize
Reports the default system page size in bytes.
hostInfo.extra.numPages
numPages (page 347) only appears on Linux systems.
hostInfo.extra.maxOpenFiles
Reports the current system limits on open le handles. See
http://docs.mongodb.org/manualreference/ulimit for more information.
maxOpenFiles (page 347) only appears on Linux systems.
hostInfo.extra.scheduler
Reports the active I/O scheduler. scheduler (page 347) only appears on OS X systems.
indexStats
Denition
indexStats
The indexStats (page 347) command aggregates statistics for the B-tree data structure that stores data for a
MongoDB index.
Warning: This command is not intended for production deployments.
The command can be run only on a mongod (page 555) instance that uses the
--enableExperimentalIndexStatsCmd option.
2.2. Database Commands 347
MongoDB Reference Manual, Release 2.6.4
To aggregate statistics, issue the command like so:
db.runCommand( { indexStats: "<collection>", index: "<index name>" } )
Output The db.collection.indexStats() (page 51) method and equivalent indexStats (page 347)
command aggregate statistics for the B-tree data structure that stores data for a MongoDB index. The commands
aggregate statistics rstly for the entire B-tree and secondly for each individual level of the B-tree. The output displays
the following values.
indexStats.index
The index name.
indexStats.version
The index version. For more information on index version numbers, see the v option in
db.collection.ensureIndex() (page 30).
indexStats.isIdIndex
If true, the index is the default _id index for the collection.
indexStats.keyPattern
The indexed keys.
indexStats.storageNs
The namespace of the indexs underlying storage.
indexStats.bucketBodyBytes
The xed size, in bytes, of a B-tree bucket in the index, not including the record header. All indexes for a given
version have the same value for this eld. MongoDB allocates xed size buckets on disk.
indexStats.depth
The number of levels in the B-tree, not including the root level.
indexStats.overall
This section of the output displays statistics for the entire B-tree.
indexStats.overall.numBuckets
The number of buckets in the entire B-tree, including all levels.
indexStats.overall.keyCount
Statistics about the number of keys in a bucket, evaluated on a per-bucket level.
indexStats.overall.usedKeyCount
Statistics about the number of used keys in a bucket, evaluated on a per-bucket level. Used keys are keys
not marked as deleted.
indexStats.overall.bsonRatio
Statistics about the percentage of the bucket body that is occupied by the key objects themselves, excluding
associated metadata.
For example, if you have the document { name: "Bob Smith" } and an index on { name: 1
}, the key object is the string Bob Smith.
indexStats.overall.keyNodeRatio
Statistics about the percentage of the bucket body that is occupied by the key node objects (the metadata
and links pertaining to the keys). This does not include the key itself. In the current implementation, a key
nodes objects consist of: the pointer to the key data (in the same bucket), the pointer to the record the key
is for, and the pointer to a child bucket.
indexStats.overall.fillRatio
The sum of the bsonRatio (page 348) and the keyNodeRatio (page 348). This shows how full the
buckets are. This will be much higher for indexes with sequential inserts.
348 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
indexStats.perLevel
This section of the output displays statistics for each level of the B-tree separately, starting with the root level.
This section displays a different document for each B-tree level.
indexStats.perLevel.numBuckets
The number of buckets at this level of the B-tree.
indexStats.perLevel.keyCount
Statistics about the number of keys in a bucket, evaluated on a per-bucket level.
indexStats.perLevel.usedKeyCount
Statistics about the number of used keys in a bucket, evaluated on a per-bucket level. Used keys are keys
not marked as deleted.
indexStats.perLevel.bsonRatio
Statistics about the percentage of the bucket body that is occupied by the key objects themselves, excluding
associated metadata.
indexStats.perLevel.keyNodeRatio
Statistics about the percentage of the bucket body that is occupied by the key node objects (the metadata
and links pertaining to the keys).
indexStats.perLevel.fillRatio
The sum of the bsonRatio (page 349) and the keyNodeRatio (page 349). This shows how full the
buckets are. This will be much higher in the following cases:
For indexes with sequential inserts, such as the _id index when using ObjectId keys.
For indexes that were recently built in the foreground with existing data.
If you recently ran compact (page 316) or --repair.
Example The following is an example of db.collection.indexStats() (page 51) and indexStats
(page 347) output.
{
"index" : "type_1_traits_1",
"version" : 1,
"isIdIndex" : false,
"keyPattern" : {
"type" : 1,
"traits" : 1
},
"storageNs" : "test.animals.$type_1_traits_1",
"bucketBodyBytes" : 8154,
"depth" : 2,
"overall" : {
"numBuckets" : 45513,
"keyCount" : {
"count" : NumberLong(45513),
"mean" : 253.89602970579836,
"stddev" : 21.784799875240708,
"min" : 52,
"max" : 290,
"quantiles" : {
"0.01" : 201.99785091648775,
// ...
"0.99" : 289.9999655156967
}
},
2.2. Database Commands 349
MongoDB Reference Manual, Release 2.6.4
"usedKeyCount" : {
"count" : NumberLong(45513),
// ...
"quantiles" : {
"0.01" : 201.99785091648775,
// ...
"0.99" : 289.9999655156967
}
},
"bsonRatio" : {
"count" : NumberLong(45513),
// ...
"quantiles" : {
"0.01" : 0.4267797891997124,
// ...
"0.99" : 0.5945548174629648
}
},
"keyNodeRatio" : {
"count" : NumberLong(45513),
// ...
"quantiles" : {
"0.01" : 0.3963656628236211,
// ...
"0.99" : 0.5690457993930765
}
},
"fillRatio" : {
"count" : NumberLong(45513),
// ...
"quantiles" : {
"0.01" : 0.9909134214926929,
// ...
"0.99" : 0.9960755457453732
}
}
},
"perLevel" : [
{
"numBuckets" : 1,
"keyCount" : {
"count" : NumberLong(1),
"mean" : 180,
"stddev" : 0,
"min" : 180,
"max" : 180
},
"usedKeyCount" : {
"count" : NumberLong(1),
// ...
"max" : 180
},
"bsonRatio" : {
"count" : NumberLong(1),
// ...
"max" : 0.3619082658817758
},
"keyNodeRatio" : {
350 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"count" : NumberLong(1),
// ...
"max" : 0.35320088300220753
},
"fillRatio" : {
"count" : NumberLong(1),
// ...
"max" : 0.7151091488839834
}
},
{
"numBuckets" : 180,
"keyCount" : {
"count" : NumberLong(180),
"mean" : 250.84444444444443,
"stddev" : 26.30057503009355,
"min" : 52,
"max" : 290
},
"usedKeyCount" : {
"count" : NumberLong(180),
// ...
"max" : 290
},
"bsonRatio" : {
"count" : NumberLong(180),
// ...
"max" : 0.5945548197203826
},
"keyNodeRatio" : {
"count" : NumberLong(180),
// ...
"max" : 0.5690458670591121
},
"fillRatio" : {
"count" : NumberLong(180),
// ...
"max" : 0.9963208241353937
}
},
{
"numBuckets" : 45332,
"keyCount" : {
"count" : NumberLong(45332),
"mean" : 253.90977675813994,
"stddev" : 21.761620836279018,
"min" : 167,
"max" : 290,
"quantiles" : {
"0.01" : 202.0000012563603,
// ...
"0.99" : 289.99996486571894
}
},
"usedKeyCount" : {
"count" : NumberLong(45332),
// ...
"quantiles" : {
2.2. Database Commands 351
MongoDB Reference Manual, Release 2.6.4
"0.01" : 202.0000012563603,
// ...
"0.99" : 289.99996486571894
}
},
"bsonRatio" : {
"count" : NumberLong(45332),
// ...
"quantiles" : {
"0.01" : 0.42678446958950583,
// ...
"0.99" : 0.5945548175411283
}
},
"keyNodeRatio" : {
"count" : NumberLong(45332),
// ...
"quantiles" : {
"0.01" : 0.39636988227885306,
// ...
"0.99" : 0.5690457981176729
}
},
"fillRatio" : {
"count" : NumberLong(45332),
// ...
"quantiles" : {
"0.01" : 0.9909246995605362,
// ...
"0.99" : 0.996075546919481
}
}
}
],
"ok" : 1
}
Additional Resources For more information on the commands limits and output, see the following:
The equivalent db.collection.indexStats() (page 51) method,
indexStats (page 347), and
https://github.com/mongodb-labs/storage-viz#readme.
isSelf
_isSelf
_isSelf (page 352) is an internal command.
listCommands
listCommands
The listCommands (page 352) command generates a list of all database commands implemented for the
current mongod (page 555) instance.
listDatabases
352 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
listDatabases
The listDatabases (page 352) command provides a list of existing databases along with basic statistics
about them:
{ listDatabases: 1 }
The value (e.g. 1) does not affect the output of the command. listDatabases (page 352) returns a document
for each database. Each document contains a name eld with the database name, a sizeOnDisk eld with
the total size of the database le on disk in bytes, and an empty eld specifying whether the database has any
data.
Example
The following operation returns a list of all databases:
db.runCommand( { listDatabases: 1 } )
See also:
http://docs.mongodb.org/manualtutorial/use-database-commands.
netstat
netstat
netstat (page 353) is an internal command that is only available on mongos (page 571) instances.
ping
ping
The ping (page 353) command is a no-op used to test whether a server is responding to commands. This
command will return immediately even if the server is write-locked:
{ ping: 1 }
The value (e.g. 1 above) does not impact the behavior of the command.
prole
profile
Use the profile (page 353) command to enable, disable, or change the query proling level. This allows
administrators to capture data regarding performance. The database proling system can impact performance
and can allow the server to write the contents of queries to the log. Your deployment should carefully consider
the security implications of this. Consider the following prototype syntax:
{ profile: <level> }
The following proling levels are available:
Level Setting
-1 No change. Returns the current prole level.
0 Off. No proling.
1 On. Only includes slow operations.
2 On. Includes all operations.
You may optionally set a threshold in milliseconds for proling using the slowms option, as follows:
{ profile: 1, slowms: 200 }
mongod (page 555) writes the output of the database proler to the system.profile collection.
2.2. Database Commands 353
MongoDB Reference Manual, Release 2.6.4
mongod (page 555) records queries that take longer than the slowOpThresholdMs to the server log even
when the database proler is not active.
See also:
Additional documentation regarding Database Proling.
See also:
db.getProfilingStatus() (page 117) and db.setProfilingLevel() (page 125) provide
wrappers around this functionality in the mongo (page 580) shell.
Note: This command obtains a write lock on the affected database and will block other operations until it has
completed. However, the write lock is only held while enabling or disabling the proler. This is typically a short
operation.
serverStatus
Denition
serverStatus
The serverStatus (page 354) command returns a document that provides an overview of the database
processs state. Most monitoring applications run this command at a regular interval to collection statistics
about the instance:
{ serverStatus: 1 }
The value (i.e. 1 above), does not affect the operation of the command.
Changed in version 2.4: In 2.4 you can dynamically suppress portions of the serverStatus (page 354)
output, or include suppressed sections by adding elds to the command document as in the following examples:
db.runCommand( { serverStatus: 1, repl: 0, indexCounters: 0 } )
db.runCommand( { serverStatus: 1, workingSet: 1, metrics: 0, locks: 0 } )
serverStatus (page 354) includes all elds by default, except workingSet (page 367), by default.
Note: You may only dynamically include top-level elds from the serverStatus (page 354) document that are
not included by default. You can exclude any eld that serverStatus (page 354) includes by default.
See also:
db.serverStatus() (page 125) and http://docs.mongodb.org/manualreference/server-status
Output The serverStatus (page 354) command returns a collection of information that reects the databases
status. These data are useful for diagnosing and assessing the performance of your MongoDB instance. This reference
catalogs each datum included in the output of this command and provides context for using this data to more effectively
administer your database.
See also:
Much of the output of serverStatus (page 354) is also displayed dynamically by mongostat (page 624). See
the mongostat (page 623) command for more information.
For examples of the serverStatus (page 354) output, see http://docs.mongodb.org/manualreference/server-status.
354 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Instance Information For an example of the instance information, see the Instance Information section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.host
The host (page 355) eld contains the systems hostname. In Unix/Linux systems, this should be the same as
the output of the hostname command.
serverStatus.version
The version (page 355) eld contains the version of MongoDB running on the current mongod (page 555)
or mongos (page 571) instance.
serverStatus.process
The process (page 355) eld identies which kind of MongoDB instance is running. Possible values are:
mongos (page 571)
mongod (page 555)
serverStatus.uptime
The value of the uptime (page 355) eld corresponds to the number of seconds that the mongos (page 571)
or mongod (page 555) process has been active.
serverStatus.uptimeEstimate
uptimeEstimate (page 355) provides the uptime as calculated from MongoDBs internal course-grained
time keeping system.
serverStatus.localTime
The localTime (page 355) value is the current time, according to the server, in UTC specied in an ISODate
format.
locks New in version 2.1.2: All locks (page 355) statuses rst appeared in the 2.1.2 development release for the
2.2 series.
For an example of the locks output, see the locks section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.locks
The locks (page 355) document contains sub-documents that provides a granular report on MongoDB
database-level lock use. All values are of the NumberLong() type.
Generally, elds named:
R refer to the global read lock,
W refer to the global write lock,
r refer to the database specic read lock, and
w refer to the database specic write lock.
If a document does not have any elds, it means that no locks have existed with this context since the last time
the mongod (page 555) started.
serverStatus.locks..
A eld named . holds the rst document in locks (page 355) that contains information about the global lock.
serverStatus.locks...timeLockedMicros
The timeLockedMicros (page 355) document reports the amount of time in microseconds that a lock has
existed in all databases in this mongod (page 555) instance.
serverStatus.locks...timeLockedMicros.R
The R eld reports the amount of time in microseconds that any database has held the global read lock.
2.2. Database Commands 355
MongoDB Reference Manual, Release 2.6.4
serverStatus.locks...timeLockedMicros.W
The W eld reports the amount of time in microseconds that any database has held the global write lock.
serverStatus.locks...timeLockedMicros.r
The r eld reports the amount of time in microseconds that any database has held the local read lock.
serverStatus.locks...timeLockedMicros.w
The w eld reports the amount of time in microseconds that any database has held the local write lock.
serverStatus.locks...timeAcquiringMicros
The timeAcquiringMicros (page 356) document reports the amount of time in microseconds that opera-
tions have spent waiting to acquire a lock in all databases in this mongod (page 555) instance.
serverStatus.locks...timeAcquiringMicros.R
The R eld reports the amount of time in microseconds that any database has spent waiting for the global read
lock.
serverStatus.locks...timeAcquiringMicros.W
The W eld reports the amount of time in microseconds that any database has spent waiting for the global write
lock.
serverStatus.locks.admin
The admin (page 356) document contains two sub-documents that report data regarding lock use in the admin
database.
serverStatus.locks.admin.timeLockedMicros
The timeLockedMicros (page 356) document reports the amount of time in microseconds that locks have
existed in the context of the admin database.
serverStatus.locks.admin.timeLockedMicros.r
The r eld reports the amount of time in microseconds that the admin database has held the read lock.
serverStatus.locks.admin.timeLockedMicros.w
The w eld reports the amount of time in microseconds that the admin database has held the write lock.
serverStatus.locks.admin.timeAcquiringMicros
The timeAcquiringMicros (page 356) document reports on the amount of eld time in microseconds that
operations have spent waiting to acquire a lock for the admin database.
serverStatus.locks.admin.timeAcquiringMicros.r
The r eld reports the amount of time in microseconds that operations have spent waiting to acquire a read lock
on the admin database.
serverStatus.locks.admin.timeAcquiringMicros.w
The w eld reports the amount of time in microseconds that operations have spent waiting to acquire a write
lock on the admin database.
serverStatus.locks.local
The local (page 356) document contains two sub-documents that report data regarding lock use in the local
database. The local database contains a number of instance specic data, including the oplog for replication.
serverStatus.locks.local.timeLockedMicros
The timeLockedMicros (page 356) document reports on the amount of time in microseconds that locks
have existed in the context of the local database.
serverStatus.locks.local.timeLockedMicros.r
The r eld reports the amount of time in microseconds that the local database has held the read lock.
serverStatus.locks.local.timeLockedMicros.w
The w eld reports the amount of time in microseconds that the local database has held the write lock.
356 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
serverStatus.locks.local.timeAcquiringMicros
The timeAcquiringMicros (page 356) document reports on the amount of time in microseconds that
operations have spent waiting to acquire a lock for the local database.
serverStatus.locks.local.timeAcquiringMicros.r
The r eld reports the amount of time in microseconds that operations have spent waiting to acquire a read lock
on the local database.
serverStatus.locks.local.timeAcquiringMicros.w
The w eld reports the amount of time in microseconds that operations have spent waiting to acquire a write
lock on the local database.
serverStatus.locks.<database>
For each additional database locks (page 355) includes a document that reports on the lock use for this
database. The names of these documents reect the database name itself.
serverStatus.locks.<database>.timeLockedMicros
The timeLockedMicros (page 357) document reports on the amount of time in microseconds that locks
have existed in the context of the <database> database.
serverStatus.locks.<database>.timeLockedMicros.r
The r eld reports the amount of time in microseconds that the <database> database has held the read lock.
serverStatus.locks.<database>.timeLockedMicros.w
The w eld reports the amount of time in microseconds that the <database> database has held the write lock.
serverStatus.locks.<database>.timeAcquiringMicros
The timeAcquiringMicros (page 357) document reports on the amount of time in microseconds that
operations have spent waiting to acquire a lock for the <database> database.
serverStatus.locks.<database>.timeAcquiringMicros.r
The r eld reports the amount of time in microseconds that operations have spent waiting to acquire a read lock
on the <database> database.
serverStatus.locks.<database>.timeAcquiringMicros.w
The w eld reports the amount of time in microseconds that operations have spent waiting to acquire a write
lock on the <database> database.
globalLock For an example of the globalLock output, see the globalLock section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.globalLock
The globalLock (page 357) data structure contains information regarding the databases current lock state,
historical lock status, current operation queue, and the number of active clients.
serverStatus.globalLock.totalTime
The value of totalTime (page 357) represents the time, in microseconds, since the database last started and
creation of the globalLock (page 357). This is roughly equivalent to total server uptime.
serverStatus.globalLock.lockTime
The value of lockTime (page 357) represents the time, in microseconds, since the database last started, that
the globalLock (page 357) has been held.
Consider this value in combination with the value of totalTime (page 357). MongoDB aggregates these
values in the ratio (page 357) value. If the ratio (page 357) value is small but totalTime (page 357) is
high the globalLock (page 357) has typically been held frequently for shorter periods of time, which may be
indicative of a more normal use pattern. If the lockTime (page 357) is higher and the totalTime (page 357)
is smaller (relatively) then fewer operations are responsible for a greater portion of servers use (relatively).
2.2. Database Commands 357
MongoDB Reference Manual, Release 2.6.4
serverStatus.globalLock.ratio
Changed in version 2.2: ratio (page 357) was removed. See locks (page 355).
The value of ratio (page 357) displays the relationship between lockTime (page 357) and totalTime
(page 357).
Low values indicate that operations have held the globalLock (page 357) frequently for shorter periods of
time. High values indicate that operations have held globalLock (page 357) infrequently for longer periods
of time.
serverStatus.globalLock.currentQueue
The currentQueue (page 358) data structure value provides more granular information concerning the num-
ber of operations queued because of a lock.
serverStatus.globalLock.currentQueue.total
The value of total (page 358) provides a combined total of operations queued waiting for the lock.
A consistently small queue, particularly of shorter operations should cause no concern. Also, consider this value
in light of the size of queue waiting for the read lock (e.g. readers (page 358)) and write lock (e.g. writers
(page 358)) individually.
serverStatus.globalLock.currentQueue.readers
The value of readers (page 358) is the number of operations that are currently queued and waiting for the
read lock. A consistently small read-queue, particularly of shorter operations should cause no concern.
serverStatus.globalLock.currentQueue.writers
The value of writers (page 358) is the number of operations that are currently queued and waiting for the
write lock. A consistently small write-queue, particularly of shorter operations is no cause for concern.
globalLock.activeClients
serverStatus.globalLock.activeClients
The activeClients (page 358) data structure provides more granular information about the number of
connected clients and the operation types (e.g. read or write) performed by these clients.
Use this data to provide context for the currentQueue (page 358) data.
serverStatus.globalLock.activeClients.total
The value of total (page 358) is the total number of active client connections to the database. This combines
clients that are performing read operations (e.g. readers (page 358)) and clients that are performing write
operations (e.g. writers (page 358)).
serverStatus.globalLock.activeClients.readers
The value of readers (page 358) contains a count of the active client connections performing read operations.
serverStatus.globalLock.activeClients.writers
The value of writers (page 358) contains a count of active client connections performing write operations.
mem For an example of the mem output, see the mem section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.mem
The mem (page 358) data structure holds information regarding the target system architecture of mongod
(page 555) and current memory use.
serverStatus.mem.bits
The value of bits (page 358) is either 64 or 32, depending on which target architecture specied during the
mongod (page 555) compilation process. In most instances this is 64, and this value does not change over time.
serverStatus.mem.resident
The value of resident (page 358) is roughly equivalent to the amount of RAM, in megabytes (MB), currently
358 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
used by the database process. In normal use this value tends to grow. In dedicated database servers this number
tends to approach the total amount of system memory.
serverStatus.mem.virtual
virtual (page 359) displays the quantity, in megabytes (MB), of virtual memory used by the mongod
(page 555) process. With journaling enabled, the value of virtual (page 359) is at least twice the value
of mapped (page 359).
If virtual (page 359) value is signicantly larger than mapped (page 359) (e.g. 3 or more times), this may
indicate a memory leak.
serverStatus.mem.supported
supported (page 359) is true when the underlying system supports extended memory information. If this
value is false and the system does not support extended memory information, then other mem (page 358) values
may not be accessible to the database server.
serverStatus.mem.mapped
The value of mapped (page 359) provides the amount of mapped memory, in megabytes (MB), by the database.
Because MongoDB uses memory-mapped les, this value is likely to be to be roughly equivalent to the total
size of your database or databases.
serverStatus.mem.mappedWithJournal
mappedWithJournal (page 359) provides the amount of mapped memory, in megabytes (MB), including
the memory used for journaling. This value will always be twice the value of mapped (page 359). This eld is
only included if journaling is enabled.
connections For an example of the connections output, see the connections section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.connections
The connections (page 359) sub document data regarding the current status of incoming connections and
availability of the database server. Use these values to assess the current load and capacity requirements of the
server.
serverStatus.connections.current
The value of current (page 359) corresponds to the number of connections to the database server from
clients. This number includes the current shell session. Consider the value of available (page 359) to add
more context to this datum.
This gure will include all incoming connections including any shell connections or connections from other
servers, such as replica set members or mongos (page 571) instances.
serverStatus.connections.available
available (page 359) provides a count of the number of unused available incoming connections the database
can provide. Consider this value in combination with the value of current (page 359) to understand the
connection load on the database, and the http://docs.mongodb.org/manualreference/ulimit
document for more information about system thresholds on available connections.
serverStatus.connections.totalCreated
totalCreated (page 359) provides a count of all incoming connections created to the server. This number
includes connections that have since closed.
extra_info For an example of the extra_info output, see the extra_info section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.extra_info
The extra_info (page 359) data structure holds data collected by the mongod (page 555) instance about the
underlying system. Your system may only report a subset of these elds.
2.2. Database Commands 359
MongoDB Reference Manual, Release 2.6.4
serverStatus.extra_info.note
The eld note (page 359) reports that the data in this structure depend on the underlying platform, and has the
text: elds vary by platform.
serverStatus.extra_info.heap_usage_bytes
The heap_usage_bytes (page 360) eld is only available on Unix/Linux systems, and reports the total size
in bytes of heap space used by the database process.
serverStatus.extra_info.page_faults
The page_faults (page 360) Reports the total number of page faults that require disk operations. Page
faults refer to operations that require the database server to access data which isnt available in active memory.
The page_faults (page 360) counter may increase dramatically during moments of poor performance and
may correlate with limited memory environments and larger data sets. Limited and sporadic page faults do not
necessarily indicate an issue.
indexCounters For an example of the indexCounters output, see the indexCounters section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.indexCounters
Changed in version 2.2: Previously, data in the indexCounters (page 360) document reported sampled data,
and were only useful in relative comparison to each other, because they could not reect absolute index use. In
2.2 and later, these data reect actual index use.
Changed in version 2.4: Fields previously in the btree sub-document of indexCounters (page 360) are
now elds in the indexCounters (page 360) document.
The indexCounters (page 360) data structure reports information regarding the state and use of indexes in
MongoDB.
serverStatus.indexCounters.accesses
accesses (page 360) reports the number of times that operations have accessed indexes. This value is the
combination of the hits (page 360) and misses (page 360). Higher values indicate that your database has
indexes and that queries are taking advantage of these indexes. If this number does not grow over time, this
might indicate that your indexes do not effectively support your use.
serverStatus.indexCounters.hits
The hits (page 360) value reects the number of times that an index has been accessed and mongod (page 555)
is able to return the index from memory.
A higher value indicates effective index use. hits (page 360) values that represent a greater proportion of the
accesses (page 360) value, tend to indicate more effective index conguration.
serverStatus.indexCounters.misses
The misses (page 360) value represents the number of times that an operation attempted to access an index
that was not in memory. These misses, do not indicate a failed query or operation, but rather an inefcient use
of the index. Lower values in this eld indicate better index use and likely overall performance as well.
serverStatus.indexCounters.resets
The resets (page 360) value reects the number of times that the index counters have been reset since the
database last restarted. Typically this value is 0, but use this value to provide context for the data specied by
other indexCounters (page 360) values.
serverStatus.indexCounters.missRatio
The missRatio (page 360) value is the ratio of hits (page 360) to misses (page 360). This value is
typically 0 or approaching 0.
backgroundFlushing For an example of the backgroundFlushing output, see the backgroundFlushing section
of the http://docs.mongodb.org/manualreference/server-status page.
360 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
serverStatus.backgroundFlushing
mongod (page 555) periodically ushes writes to disk. In the default conguration, this happens every 60
seconds. The backgroundFlushing (page 360) data structure contains data regarding these operations.
Consider these values if you have concerns about write performance and journaling (page 365).
serverStatus.backgroundFlushing.flushes
flushes (page 361) is a counter that collects the number of times the database has ushed all writes to disk.
This value will grow as database runs for longer periods of time.
serverStatus.backgroundFlushing.total_ms
The total_ms (page 361) value provides the total number of milliseconds (ms) that the mongod (page 555)
processes have spent writing (i.e. ushing) data to disk. Because this is an absolute value, consider the value of
flushes (page 361) and average_ms (page 361) to provide better context for this datum.
serverStatus.backgroundFlushing.average_ms
The average_ms (page 361) value describes the relationship between the number of ushes and the total
amount of time that the database has spent writing data to disk. The larger flushes (page 361) is, the more
likely this value is likely to represent a normal, time; however, abnormal data can skew this value.
Use the last_ms (page 361) to ensure that a high average is not skewed by transient historical issue or a
random write distribution.
serverStatus.backgroundFlushing.last_ms
The value of the last_ms (page 361) eld is the amount of time, in milliseconds, that the last ush operation
took to complete. Use this value to verify that the current performance of the server and is in line with the
historical data provided by average_ms (page 361) and total_ms (page 361).
serverStatus.backgroundFlushing.last_finished
The last_finished (page 361) eld provides a timestamp of the last completed ush operation in the
ISODate format. If this value is more than a fewminutes old relative to your servers current time and accounting
for differences in time zone, restarting the database may result in some data loss.
Also consider ongoing operations that might skew this value by routinely block write operations.
cursors Deprecated since version 2.6: See the serverStatus.metrics.cursor (page 367) eld instead.
For an example of the cursors output, see the cursors section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.cursors
The cursors (page 361) data structure contains data regarding cursor state and use.
serverStatus.cursors.note
A note specifying to use the serverStatus.metrics.cursor (page 371) eld instead of
serverStatus.cursors (page 361).
serverStatus.cursors.totalOpen
totalOpen (page 361) provides the number of cursors that MongoDB is maintaining for clients. Because
MongoDB exhausts unused cursors, typically this value small or zero. However, if there is a queue, stale
tailable cursor, or a large number of operations, this value may rise.
serverStatus.cursors.clientCursors_size
Deprecated since version 1.x: See totalOpen (page 361) for this datum.
serverStatus.cursors.timedOut
timedOut (page 361) provides a counter of the total number of cursors that have timed out since the server
process started. If this number is large or growing at a regular rate, this may indicate an application error.
2.2. Database Commands 361
MongoDB Reference Manual, Release 2.6.4
serverStatus.cursors.totalNoTimeout
totalNoTimeout (page 361) provides the number of open cursors with the option
DBQuery.Option.noTimeout (page 80) set to prevent timeout after a period of inactivity.
serverStatus.cursors.pinned
serverStatus.cursors.pinned (page 362) provides the number of pinned open cursors.
network For an example of the network output, see the network section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.network
The network (page 362) data structure contains data regarding MongoDBs network use.
serverStatus.network.bytesIn
The value of the bytesIn (page 362) eld reects the amount of network trafc, in bytes, received by this
database. Use this value to ensure that network trafc sent to the mongod (page 555) process is consistent with
expectations and overall inter-application trafc.
serverStatus.network.bytesOut
The value of the bytesOut (page 362) eld reects the amount of network trafc, in bytes, sent from this
database. Use this value to ensure that network trafc sent by the mongod (page 555) process is consistent with
expectations and overall inter-application trafc.
serverStatus.network.numRequests
The numRequests (page 362) eld is a counter of the total number of distinct requests that the server has
received. Use this value to provide context for the bytesIn (page 362) and bytesOut (page 362) values to
ensure that MongoDBs network utilization is consistent with expectations and application use.
repl For an example of the repl output, see the repl section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.repl
The repl (page 362) data structure contains status information for MongoDBs replication (i.e. replica set)
conguration. These values only appear when the current host has replication enabled.
See http://docs.mongodb.org/manualreplication for more information on replication.
serverStatus.repl.setName
The setName (page 362) eld contains a string with the name of the current replica set. This value reects the
--replSet command line argument, or replSetName value in the conguration le.
See http://docs.mongodb.org/manualreplication for more information on replication.
serverStatus.repl.ismaster
The value of the ismaster (page 362) eld is either true or false and reects whether the current node is
the master or primary node in the replica set.
See http://docs.mongodb.org/manualreplication for more information on replication.
serverStatus.repl.secondary
The value of the secondary (page 362) eld is either true or false and reects whether the current node
is a secondary node in the replica set.
See http://docs.mongodb.org/manualreplication for more information on replication.
serverStatus.repl.hosts
hosts (page 362) is an array that lists the other nodes in the current replica set. Each member of the replica set
appears in the form of hostname:port.
See http://docs.mongodb.org/manualreplication for more information on replication.
362 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
opcountersRepl For an example of the opcountersRepl output, see the opcountersRepl section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.opcountersRepl
The opcountersRepl (page 363) data structure, similar to the opcounters (page 363) data structure,
provides an overview of database replication operations by type and makes it possible to analyze the load on the
replica in more granular manner. These values only appear when the current host has replication enabled.
These values will differ from the opcounters (page 363) values because of how MongoDB serializes oper-
ations during replication. See http://docs.mongodb.org/manualreplication for more informa-
tion on replication.
These numbers will grow over time in response to database use. Analyze these values over time to track database
utilization.
serverStatus.opcountersRepl.insert
insert (page 363) provides a counter of the total number of replicated insert operations since the mongod
(page 555) instance last started.
serverStatus.opcountersRepl.query
query (page 363) provides a counter of the total number of replicated queries since the mongod (page 555)
instance last started.
serverStatus.opcountersRepl.update
update (page 363) provides a counter of the total number of replicated update operations since the mongod
(page 555) instance last started.
serverStatus.opcountersRepl.delete
delete (page 363) provides a counter of the total number of replicated delete operations since the mongod
(page 555) instance last started.
serverStatus.opcountersRepl.getmore
getmore (page 363) provides a counter of the total number of getmore operations since the mongod
(page 555) instance last started. This counter can be high even if the query count is low. Secondary nodes
send getMore operations as part of the replication process.
serverStatus.opcountersRepl.command
command (page 363) provides a counter of the total number of replicated commands issued to the database
since the mongod (page 555) instance last started.
opcounters For an example of the opcounters output, see the opcounters section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.opcounters
The opcounters (page 363) data structure provides an overview of database operations by type and makes it
possible to analyze the load on the database in more granular manner.
These numbers will grow over time and in response to database use. Analyze these values over time to track
database utilization.
Note: The data in opcounters (page 363) treats operations that affect multiple documents, such as bulk insert
or multi-update operations, as a single operation. See document (page 367) for more granular document-level
operation tracking.
serverStatus.opcounters.insert
insert (page 363) provides a counter of the total number of insert operations since the mongod (page 555)
instance last started.
2.2. Database Commands 363
MongoDB Reference Manual, Release 2.6.4
serverStatus.opcounters.query
query (page 363) provides a counter of the total number of queries since the mongod (page 555) instance last
started.
serverStatus.opcounters.update
update (page 364) provides a counter of the total number of update operations since the mongod (page 555)
instance last started.
serverStatus.opcounters.delete
delete (page 364) provides a counter of the total number of delete operations since the mongod (page 555)
instance last started.
serverStatus.opcounters.getmore
getmore (page 364) provides a counter of the total number of getmore operations since the mongod
(page 555) instance last started. This counter can be high even if the query count is low. Secondary nodes
send getMore operations as part of the replication process.
serverStatus.opcounters.command
command (page 364) provides a counter of the total number of commands issued to the database since the
mongod (page 555) instance last started.
asserts For an example of the asserts output, see the asserts section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.asserts
The asserts (page 364) document reports the number of asserts on the database. While assert errors are
typically uncommon, if there are non-zero values for the asserts (page 364), you should check the log le
for the mongod (page 555) process for more information. In many cases these errors are trivial, but are worth
investigating.
serverStatus.asserts.regular
The regular (page 364) counter tracks the number of regular assertions raised since the server process started.
Check the log le for more information about these messages.
serverStatus.asserts.warning
The warning (page 364) counter tracks the number of warnings raised since the server process started. Check
the log le for more information about these warnings.
serverStatus.asserts.msg
The msg (page 364) counter tracks the number of message assertions raised since the server process started.
Check the log le for more information about these messages.
serverStatus.asserts.user
The user (page 364) counter reports the number of user asserts that have occurred since the last time the
server process started. These are errors that user may generate, such as out of disk space or duplicate key. You
can prevent these assertions by xing a problem with your application or deployment. Check the MongoDB log
for more information.
serverStatus.asserts.rollovers
The rollovers (page 364) counter displays the number of times that the rollover counters have rolled over
since the last time the server process started. The counters will rollover to zero after 2
30
assertions. Use this
value to provide context to the other values in the asserts (page 364) data structure.
writeBacksQueued For an example of the writeBacksQueued output, see the writeBacksQueued section of the
http://docs.mongodb.org/manualreference/server-status page.
364 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
serverStatus.writeBacksQueued
The value of writeBacksQueued (page 364) is true when there are operations from a mongos (page 571)
instance queued for retrying. Typically this option is false.
See also:
writeBacks
Journaling (dur) New in version 1.8.
For an example of the Journaling (dur) output, see the journaling section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.dur
The dur (page 365) (for durability) document contains data regarding the mongod (page 555)s journaling-
related operations and performance. mongod (page 555) must be running with journaling for these data to
appear in the output of serverStatus (page 354).
MongoDB reports the data in dur (page 365) based on 3 second intervals of data, collected between 3 and 6
seconds in the past.
See also:
http://docs.mongodb.org/manualcore/journaling for more information about journaling op-
erations.
serverStatus.dur.commits
The commits (page 365) provides the number of transactions written to the journal during the last journal
group commit interval.
serverStatus.dur.journaledMB
The journaledMB (page 365) provides the amount of data in megabytes (MB) written to journal during the
last journal group commit interval.
serverStatus.dur.writeToDataFilesMB
The writeToDataFilesMB (page 365) provides the amount of data in megabytes (MB) written from journal
to the data les during the last journal group commit interval.
serverStatus.dur.compression
New in version 2.0.
The compression (page 365) represents the compression ratio of the data written to the journal:
( journaled_size_of_data / uncompressed_size_of_data )
serverStatus.dur.commitsInWriteLock
The commitsInWriteLock (page 365) provides a count of the commits that occurred while a write lock was
held. Commits in a write lock indicate a MongoDB node under a heavy write load and call for further diagnosis.
serverStatus.dur.earlyCommits
The earlyCommits (page 365) value reects the number of times MongoDB requested a commit before the
scheduled journal group commit interval. Use this value to ensure that your journal group commit interval is
not too long for your deployment.
serverStatus.dur.timeMS
The timeMS (page 365) document provides information about the performance of the mongod (page 555)
instance during the various phases of journaling in the last journal group commit interval.
serverStatus.dur.timeMS.dt
The dt (page 365) value provides, in milliseconds, the amount of time over which MongoDB collected the
timeMS (page 365) data. Use this eld to provide context to the other timeMS (page 365) eld values.
2.2. Database Commands 365
MongoDB Reference Manual, Release 2.6.4
serverStatus.dur.timeMS.prepLogBuffer
The prepLogBuffer (page 365) value provides, in milliseconds, the amount of time spent preparing to write
to the journal. Smaller values indicate better journal performance.
serverStatus.dur.timeMS.writeToJournal
The writeToJournal (page 366) value provides, in milliseconds, the amount of time spent actually writing
to the journal. File system speeds and device interfaces can affect performance.
serverStatus.dur.timeMS.writeToDataFiles
The writeToDataFiles (page 366) value provides, in milliseconds, the amount of time spent writing to
data les after journaling. File system speeds and device interfaces can affect performance.
serverStatus.dur.timeMS.remapPrivateView
The remapPrivateView (page 366) value provides, in milliseconds, the amount of time spent remapping
copy-on-write memory mapped views. Smaller values indicate better journal performance.
recordStats For an example of the recordStats output, see the recordStats section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.recordStats
The recordStats (page 366) document provides ne grained reporting on page faults on a per database level.
MongoDB uses a read lock on each database to return recordStats (page 366). To minimize this overhead,
you can disable this section, as in the following operation:
db.serverStatus( { recordStats: 0 } )
serverStatus.recordStats.accessesNotInMemory
accessesNotInMemory (page 366) reects the number of times mongod (page 555) needed to access a
memory page that was not resident in memory for all databases managed by this mongod (page 555) instance.
serverStatus.recordStats.pageFaultExceptionsThrown
pageFaultExceptionsThrown (page 366) reects the number of page fault exceptions thrown by
mongod (page 555) when accessing data for all databases managed by this mongod (page 555) instance.
serverStatus.recordStats.local.accessesNotInMemory
accessesNotInMemory (page 366) reects the number of times mongod (page 555) needed to access a
memory page that was not resident in memory for the local database.
serverStatus.recordStats.local.pageFaultExceptionsThrown
pageFaultExceptionsThrown (page 366) reects the number of page fault exceptions thrown by
mongod (page 555) when accessing data for the local database.
serverStatus.recordStats.admin.accessesNotInMemory
accessesNotInMemory (page 366) reects the number of times mongod (page 555) needed to access a
memory page that was not resident in memory for the admin database.
serverStatus.recordStats.admin.pageFaultExceptionsThrown
pageFaultExceptionsThrown (page 366) reects the number of page fault exceptions thrown by
mongod (page 555) when accessing data for the admin database.
serverStatus.recordStats.<database>.accessesNotInMemory
accessesNotInMemory (page 366) reects the number of times mongod (page 555) needed to access a
memory page that was not resident in memory for the <database> database.
serverStatus.recordStats.<database>.pageFaultExceptionsThrown
pageFaultExceptionsThrown (page 366) reects the number of page fault exceptions thrown by
mongod (page 555) when accessing data for the <database> database.
366 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
workingSet New in version 2.4.
Note: The workingSet (page 367) data is only included in the output of serverStatus (page 354) if explicitly
enabled. To return the workingSet (page 367), use one of the following commands:
db.serverStatus( { workingSet: 1 } )
db.runCommand( { serverStatus: 1, workingSet: 1 } )
For an example of the workingSet output, see the workingSet section of the
http://docs.mongodb.org/manualreference/server-status page.
serverStatus.workingSet
workingSet (page 367) is a document that contains values useful for estimating the size of the working set,
which is the amount of data that MongoDB uses actively. workingSet (page 367) uses an internal data
structure that tracks pages accessed by mongod (page 555).
serverStatus.workingSet.note
note (page 367) is a eld that holds a string warning that the workingSet (page 367) document is an
estimate.
serverStatus.workingSet.pagesInMemory
pagesInMemory (page 367) contains a count of the total number of pages accessed by mongod (page 555)
over the period displayed in overSeconds (page 367). The default page size is 4 kilobytes: to convert this
value to the amount of data in memory multiply this value by 4 kilobytes.
If your total working set is less than the size of physical memory, over time the value of pagesInMemory
(page 367) will reect your data size.
Use pagesInMemory (page 367) in conjunction with overSeconds (page 367) to help estimate the actual
size of the working set.
serverStatus.workingSet.computationTimeMicros
computationTimeMicros (page 367) reports the amount of time the mongod (page 555) instance used to
compute the other elds in the workingSet (page 367) section.
Reporting on workingSet (page 367) may impact the performance of other operations on the mongod
(page 555) instance because MongoDB must collect some data within the context of a lock. Ensure that au-
tomated monitoring tools consider this metric when determining the frequency of collection for workingSet
(page 367).
serverStatus.workingSet.overSeconds
overSeconds (page 367) returns the amount of time elapsed between the newest and oldest pages tracked in
the pagesInMemory (page 367) data point.
If overSeconds (page 367) is decreasing, or if pagesInMemory (page 367) equals physical RAM and
overSeconds (page 367) is very small, the working set may be much larger than physical RAM.
When overSeconds (page 367) is large, MongoDBs data set is equal to or smaller than physical RAM.
metrics For an example of the metrics output, see the metrics section of the
http://docs.mongodb.org/manualreference/server-status page.
New in version 2.4.
serverStatus.metrics
The metrics (page 367) document holds a number of statistics that reect the current use and state of a
running mongod (page 555) instance.
serverStatus.metrics.document
The document (page 367) holds a document of that reect document access and modication patterns and data
2.2. Database Commands 367
MongoDB Reference Manual, Release 2.6.4
use. Compare these values to the data in the opcounters (page 363) document, which track total number of
operations.
serverStatus.metrics.document.deleted
deleted (page 368) reports the total number of documents deleted.
serverStatus.metrics.document.inserted
inserted (page 368) reports the total number of documents inserted.
serverStatus.metrics.document.returned
returned (page 368) reports the total number of documents returned by queries.
serverStatus.metrics.document.updated
updated (page 368) reports the total number of documents updated.
serverStatus.metrics.getLastError
getLastError (page 368) is a document that reports on getLastError (page 243) use.
serverStatus.metrics.getLastError.wtime
wtime (page 368) is a sub-document that reports getLastError (page 243) operation counts with a w
argument greater than 1.
serverStatus.metrics.getLastError.wtime.num
num (page 368) reports the total number of getLastError (page 243) operations with a specied write
concern (i.e. w) that wait for one or more members of a replica set to acknowledge the write operation (i.e. a w
value greater than 1.)
serverStatus.metrics.getLastError.wtime.totalMillis
totalMillis (page 368) reports the total amount of time in milliseconds that the mongod (page 555) has
spent performing getLastError (page 243) operations with write concern (i.e. w) that wait for one or more
members of a replica set to acknowledge the write operation (i.e. a w value greater than 1.)
serverStatus.metrics.getLastError.wtimeouts
wtimeouts (page 368) reports the number of times that write concern operations have timed out as a result of
the wtimeout threshold to getLastError (page 243).
serverStatus.metrics.operation
operation (page 368) is a sub-document that holds counters for several types of update and query operations
that MongoDB handles using special operation types.
serverStatus.metrics.operation.fastmod
fastmod (page 368) reports the number of update operations that neither cause documents to grow nor
require updates to the index. For example, this counter would record an update operation that use the $inc
(page 430) operator to increment the value of a eld that is not indexed.
serverStatus.metrics.operation.idhack
idhack (page 368) reports the number of queries that contain the _id eld. For these queries, MongoDB will
use default index on the _id eld and skip all query plan analysis.
serverStatus.metrics.operation.scanAndOrder
scanAndOrder (page 368) reports the total number of queries that return sorted numbers that cannot perform
the sort operation using an index.
serverStatus.metrics.queryExecutor
queryExecutor (page 368) is a document that reports data from the query execution system.
serverStatus.metrics.queryExecutor.scanned
scanned (page 368) reports the total number of index items scanned during queries and query-plan evaluation.
This counter is the same as nscanned (page 86) in the output of explain() (page 83).
serverStatus.metrics.record
record (page 368) is a document that reports data related to record allocation in the on-disk memory les.
368 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
serverStatus.metrics.record.moves
moves (page 368) reports the total number of times documents move within the on-disk representation of the
MongoDB data set. Documents move as a result of operations that increase the size of the document beyond
their allocated record size.
serverStatus.metrics.repl
repl (page 369) holds a sub-document that reports metrics related to the replication process. repl (page 369)
document appears on all mongod (page 555) instances, even those that arent members of replica sets.
serverStatus.metrics.repl.apply
apply (page 369) holds a sub-document that reports on the application of operations from the replication oplog.
serverStatus.metrics.repl.apply.batches
batches (page 369) reports on the oplog application process on secondaries members of replica sets. See
replica-set-internals-multi-threaded-replication for more information on the oplog application processes
serverStatus.metrics.repl.apply.batches.num
num (page 369) reports the total number of batches applied across all databases.
serverStatus.metrics.repl.apply.batches.totalMillis
totalMillis (page 369) reports the total amount of time the mongod (page 555) has spent applying opera-
tions from the oplog.
serverStatus.metrics.repl.apply.ops
ops (page 369) reports the total number of oplog operations applied.
serverStatus.metrics.repl.buffer
MongoDB buffers oplog operations from the replication sync source buffer before applying oplog entries in a
batch. buffer (page 369) provides a way to track the oplog buffer. See replica-set-internals-multi-threaded-
replication for more information on the oplog application process.
serverStatus.metrics.repl.buffer.count
count (page 369) reports the current number of operations in the oplog buffer.
serverStatus.metrics.repl.buffer.maxSizeBytes
maxSizeBytes (page 369) reports the maximum size of the buffer. This value is a constant setting in the
mongod (page 555), and is not congurable.
serverStatus.metrics.repl.buffer.sizeBytes
sizeBytes (page 369) reports the current size of the contents of the oplog buffer.
serverStatus.metrics.repl.network
network (page 369) reports network use by the replication process.
serverStatus.metrics.repl.network.bytes
bytes (page 369) reports the total amount of data read from the replication sync source.
serverStatus.metrics.repl.network.getmores
getmores (page 369) reports on the getmore operations, which are requests for additional results from the
oplog cursor as part of the oplog replication process.
serverStatus.metrics.repl.network.getmores.num
num (page 369) reports the total number of getmore operations, which are operations that request an additional
set of operations from the replication sync source.
serverStatus.metrics.repl.network.getmores.totalMillis
totalMillis (page 369) reports the total amount of time required to collect data fromgetmore operations.
Note: This number can be quite large, as MongoDB will wait for more data even if the getmore operation
does not initial return data.
2.2. Database Commands 369
MongoDB Reference Manual, Release 2.6.4
serverStatus.metrics.repl.network.ops
ops (page 369) reports the total number of operations read from the replication source.
serverStatus.metrics.repl.network.readersCreated
readersCreated (page 370) reports the total number of oplog query processes created. MongoDB will
create a new oplog query any time an error occurs in the connection, including a timeout, or a network operation.
Furthermore, readersCreated (page 370) will increment every time MongoDB selects a new source fore
replication.
serverStatus.metrics.repl.oplog
oplog (page 370) is a document that reports on the size and use of the oplog by this mongod (page 555)
instance.
serverStatus.metrics.repl.oplog.insert
insert (page 370) is a document that reports insert operations into the oplog.
serverStatus.metrics.repl.oplog.insert.num
num (page 370) reports the total number of items inserted into the oplog.
serverStatus.metrics.repl.oplog.insert.totalMillis
totalMillis (page 370) reports the total amount of time spent for the mongod (page 555) to insert data into
the oplog.
serverStatus.metrics.repl.oplog.insertBytes
insertBytes (page 370) the total size of documents inserted into the oplog.
serverStatus.metrics.repl.preload
preload (page 370) reports on the pre-fetch stage, where MongoDB loads documents and indexes into
RAM to improve replication throughput.
See replica-set-internals-multi-threaded-replication for more information about the pre-fetch stage of the repli-
cation process.
serverStatus.metrics.repl.preload.docs
docs (page 370) is a sub-document that reports on the documents loaded into memory during the pre-fetch
stage.
serverStatus.metrics.repl.preload.docs.num
num (page 370) reports the total number of documents loaded during the pre-fetch stage of replication.
serverStatus.metrics.repl.preload.docs.totalMillis
totalMillis (page 370) reports the total amount of time spent loading documents as part of the pre-fetch
stage of replication.
serverStatus.metrics.repl.preload.indexes
indexes (page 370) is a sub-document that reports on the index items loaded into memory during the pre-fetch
stage of replication.
See replica-set-internals-multi-threaded-replication for more information about the pre-fetch stage of replica-
tion.
serverStatus.metrics.repl.preload.indexes.num
num (page 370) reports the total number of index entries loaded by members before updating documents as part
of the pre-fetch stage of replication.
serverStatus.metrics.repl.preload.indexes.totalMillis
totalMillis (page 370) reports the total amount of time spent loading index entries as part of the pre-fetch
stage of replication.
serverStatus.metrics.ttl
ttl (page 370) is a sub-document that reports on the operation of the resource use of the ttl index process.
370 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
serverStatus.metrics.ttl.deletedDocuments
deletedDocuments (page 370) reports the total number of documents deleted from collections with a ttl
index.
serverStatus.metrics.ttl.passes
passes (page 371) reports the number of times the background process removes documents from collections
with a ttl index.
serverStatus.metrics.cursor
New in version 2.6.
The cursor (page 371) is a document that contains data regarding cursor state and use.
serverStatus.metrics.cursor.timedOut
New in version 2.6.
timedOut (page 371) provides the total number of cursors that have timed out since the server process started.
If this number is large or growing at a regular rate, this may indicate an application error.
serverStatus.metrics.cursor.open
New in version 2.6.
The open (page 371) is an embedded document that contains data regarding open cursors.
serverStatus.metrics.cursor.open.noTimeout
New in version 2.6.
noTimeout (page 371) provides the number of open cursors with the option
DBQuery.Option.noTimeout (page 80) set to prevent timeout after a period of inactivity.
serverStatus.metrics.cursor.open.pinned
New in version 2.6.
serverStatus.metrics.cursor.open.pinned (page 371) provides the number of pinned open
cursors.
serverStatus.metrics.cursor.open.total
New in version 2.6.
total (page 371) provides the number of cursors that MongoDB is maintaining for clients. Because MongoDB
exhausts unused cursors, typically this value small or zero. However, if there is a queue, stale tailable cursors,
or a large number of operations this value may rise.
shardConnPoolStats
Denition
shardConnPoolStats
Returns information on the pooled and cached connections in the sharded connection pool. The command also
returns information on the per-thread connection cache in the connection pool.
The shardConnPoolStats (page 371) command uses the following syntax:
{ shardConnPoolStats: 1 }
The sharded connection pool is specic to connections between members in a sharded cluster. The mongos
(page 571) instances in a cluster use the connection pool to execute client reads and writes. The mongod
(page 555) instances in a cluster use the pool when issuing mapReduce (page 218) to query temporary collec-
tions on other shards.
When the cluster requires a connection, MongoDB pulls a connection from the sharded connection pool into the
per-thread connection cache. MongoDB returns the connection to the connection pool after every operation.
2.2. Database Commands 371
MongoDB Reference Manual, Release 2.6.4
Output
shardConnPoolStats.hosts
Displays connection status for each cong server, replica set, and standalone instance in the cluster.
shardConnPoolStats.hosts.<host>.available
The number of connections available for this host to connect to the mongos (page 571).
shardConnPoolStats.hosts.<host>.created
The number of connections the host has ever created to connect to the mongos (page 571).
shardConnPoolStats.replicaSets
Displays information specic to replica sets.
shardConnPoolStats.replicaSets.<name>.host
Holds an array of documents that report on each replica set member. These values derive from the replica
set status (page 289) values.
shardConnPoolStats.replicaSets.<name>.host[n].addr
The host address in the format [hostname]:[port].
shardConnPoolStats.replicaSets.<name>.host[n].ok
This eld is for internal use. Reports false when the mongos (page 571) either cannot connect to
instance or received a connection exception or error.
shardConnPoolStats.replicaSets.<name>.host[n].ismaster
The host is the replica sets primary if this is set to true.
shardConnPoolStats.replicaSets.<name>.host[n].hidden
The host is a hidden member of the replica set if this is set to true.
shardConnPoolStats.replicaSets.<name>.host[n].secondary
The host is a hidden member of the replica set if this is set to true.
The host is a secondary member of the replica set if this is set to true.
shardConnPoolStats.replicaSets.<name>.host[n].pingTimeMillis
The latency, in milliseconds, from the mongos (page 571) to this member.
shardConnPoolStats.replicaSets.<name>.host[n].tags
The member has tags congured.
shardConnPoolStats.createdByType
The number connections in the clusters connection pool.
shardConnPoolStats.createdByType.master
The number of connections to a shard.
shardConnPoolStats.createdByType.set
The number of connections to a replica set.
shardConnPoolStats.createdByType.sync
The number of connections to the cong database.
shardConnPoolStats.totalAvailable
The number of connections available from the mongos (page 571) to the cong servers, replica sets, and
standalone mongod (page 555) instances in the cluster.
shardConnPoolStats.totalCreated
The number of connections the mongos (page 571) has ever created to other members of the cluster.
shardConnPoolStats.threads
Displays information on the per-thread connection cache.
372 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
shardConnPoolStats.threads.hosts
Displays each incoming client connection. For a mongos (page 571), this array eld displays one doc-
ument per incoming client thread. For a mongod (page 555), the array displays one entry per incoming
sharded mapReduce (page 218) client thread.
shardConnPoolStats.threads.hosts.host
The host using the connection. The host can be a cong server, replica set, or standalone instance.
shardConnPoolStats.threads.hosts.created
The number of times the host pulled a connection from the pool.
shardConnPoolStats.threads.hosts.avail
The threads availability.
shardConnPoolStats.threads.seenNS
The namespaces used on this connection thus far.
top
top
top (page 373) is an administrative command that returns usage statistics for each collection. top (page 373)
provides amount of time, in microseconds, used and a count of operations for the following event types:
total
readLock
writeLock
queries
getmore
insert
update
remove
commands
Issue the top (page 373) command against the admin database in the form:
{ top: 1 }
Example At the mongo (page 580) shell prompt, use top (page 373) with the following evocation:
db.adminCommand("top")
Alternately you can use top (page 373) as follows:
use admin
db.runCommand( { top: 1 } )
The output of the top command would resemble the following output:
{
"totals" : {
"records.users" : {
"total" : {
"time" : 305277,
"count" : 2825
},
2.2. Database Commands 373
MongoDB Reference Manual, Release 2.6.4
"readLock" : {
"time" : 305264,
"count" : 2824
},
"writeLock" : {
"time" : 13,
"count" : 1
},
"queries" : {
"time" : 305264,
"count" : 2824
},
"getmore" : {
"time" : 0,
"count" : 0
},
"insert" : {
"time" : 0,
"count" : 0
},
"update" : {
"time" : 0,
"count" : 0
},
"remove" : {
"time" : 0,
"count" : 0
},
"commands" : {
"time" : 0,
"count" : 0
}
}
}
validate
Denition
validate
The validate (page 374) command checks the structures within a namespace for correctness by scanning
the collections data and indexes. The command returns information regarding the on-disk representation of the
collection.
The validate command can be slow, particularly on larger data sets.
The following example validates the contents of the collection named users.
{ validate: "users" }
You may also specify one of the following options:
full: true provides a more thorough scan of the data.
scandata: false skips the scan of the base collection without skipping the scan of the index.
The mongo (page 580) shell also provides a wrapper:
374 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.validate();
Use one of the following forms to perform the full collection validation:
db.collection.validate(true)
db.runCommand( { validate: "collection", full: true } )
Warning: This command is resource intensive and may have an impact on the performance of your Mon-
goDB instance.
Output
validate.ns
The full namespace name of the collection. Namespaces include the database name and the collection name in
the form database.collection.
validate.firstExtent
The disk location of the rst extent in the collection. The value of this eld also includes the namespace.
validate.lastExtent
The disk location of the last extent in the collection. The value of this eld also includes the namespace.
validate.extentCount
The number of extents in the collection.
validate.extents
validate (page 374) returns one instance of this document for every extent in the collection. This sub-
document is only returned when you specify the full option to the command.
validate.extents.loc
The disk location for the beginning of this extent.
validate.extents.xnext
The disk location for the extent following this one. null if this is the end of the linked list of extents.
validate.extents.xprev
The disk location for the extent preceding this one. null if this is the head of the linked list of extents.
validate.extents.nsdiag
The namespace this extent belongs to (should be the same as the namespace shown at the beginning of the
validate listing).
validate.extents.size
The number of bytes in this extent.
validate.extents.firstRecord
The disk location of the rst record in this extent.
validate.extents.lastRecord
The disk location of the last record in this extent.
validate.datasize
The number of bytes in all data records. This value does not include deleted records, nor does it include extent
headers, nor record headers, nor space in a le unallocated to any extent. datasize (page 375) includes record
padding.
validate.nrecords
The number of documents in the collection.
validate.lastExtentSize
The size of the last new extent created in this collection. This value determines the size of the next extent created.
2.2. Database Commands 375
MongoDB Reference Manual, Release 2.6.4
validate.padding
A oating point value between 1 and 2.
When MongoDB creates a new record it uses the padding factor to determine how much additional space to add
to the record. The padding factor is automatically adjusted by mongo when it notices that update operations are
triggering record moves.
validate.firstExtentDetails
The size of the rst extent created in this collection. This data is similar to the data provided by the extents
(page 375) sub-document; however, the data reects only the rst extent in the collection and is always returned.
validate.firstExtentDetails.loc
The disk location for the beginning of this extent.
validate.firstExtentDetails.xnext
The disk location for the extent following this one. null if this is the end of the linked list of extents,
which should only be the case if there is only one extent.
validate.firstExtentDetails.xprev
The disk location for the extent preceding this one. This should always be null.
validate.firstExtentDetails.nsdiag
The namespace this extent belongs to (should be the same as the namespace shown at the beginning of the
validate listing).
validate.firstExtentDetails.size
The number of bytes in this extent.
validate.firstExtentDetails.firstRecord
The disk location of the rst record in this extent.
validate.firstExtentDetails.lastRecord
The disk location of the last record in this extent.
validate.objectsFound
The number of records actually encountered in a scan of the collection. This eld should have the same value
as the nrecords (page 375) eld.
validate.invalidObjects
The number of records containing BSON documents that do not pass a validation check.
Note: This eld is only included in the validation output when you specify the full option.
validate.bytesWithHeaders
This is similar to datasize, except that bytesWithHeaders (page 376) includes the record headers. In version
2.0, record headers are 16 bytes per document.
Note: This eld is only included in the validation output when you specify the full option.
validate.bytesWithoutHeaders
bytesWithoutHeaders (page 376) returns data collected from a scan of all records. The value should be
the same as datasize (page 375).
Note: This eld is only included in the validation output when you specify the full option.
validate.deletedCount
The number of deleted or free records in the collection.
376 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
validate.deletedSize
The size of all deleted or free records in the collection.
validate.nIndexes
The number of indexes on the data in the collection.
validate.keysPerIndex
A document containing a eld for each index, named after the indexs name, that contains the number of keys,
or documents referenced, included in the index.
validate.valid
Boolean. true, unless validate (page 374) determines that an aspect of the collection is not valid. When
false, see the errors (page 377) eld for more information.
validate.errors
Typically empty; however, if the collection is not valid (i.e valid (page 377) is false), this eld will contain a
message describing the validation error.
validate.ok
Set to 1 when the command succeeds. If the command fails the ok (page 377) eld has a value of 0.
whatsmyuri
whatsmyuri
whatsmyuri (page 377) is an internal command.
2.2.3 Internal Commands
Internal Commands
Name Description
_migrateClone (page 378) Internal command that supports chunk migration. Do not call directly.
_recvChunkAbort (page 378) Internal command that supports chunk migrations in sharded clusters. Do not
call directly.
_recvChunkCommit
(page 378)
Internal command that supports chunk migrations in sharded clusters. Do not
call directly.
_recvChunkStart (page 378) Internal command that facilitates chunk migrations in sharded clusters.. Do
not call directly.
_recvChunkStatus
(page 378)
Internal command that returns data to support chunk migrations in sharded
clusters. Do not call directly.
_replSetFresh Internal command that supports replica set election operations.
_transferMods (page 378) Internal command that supports chunk migrations. Do not call directly.
handshake (page 378) Internal command.
mapreduce.shardedfinish
(page 379)
Internal command that supports map-reduce in sharded cluster
environments.
replSetElect (page 379) Internal command that supports replica set functionality.
replSetGetRBID (page 379) Internal command that supports replica set operations.
replSetHeartbeat
(page 379)
Internal command that supports replica set operations.
writeBacksQueued
(page 379)
Internal command that supports chunk migrations in sharded clusters.
writebacklisten (page 380) Internal command that supports chunk migrations in sharded clusters.
2.2. Database Commands 377
MongoDB Reference Manual, Release 2.6.4
migrateClone
_migrateClone
_migrateClone (page 378) is an internal command. Do not call directly.
recvChunkAbort
_recvChunkAbort
_recvChunkAbort (page 378) is an internal command. Do not call directly.
recvChunkCommit
_recvChunkCommit
_recvChunkCommit (page 378) is an internal command. Do not call directly.
recvChunkStart
_recvChunkStart
_recvChunkStart (page 378) is an internal command. Do not call directly.
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed.
recvChunkStatus
_recvChunkStatus
_recvChunkStatus (page 378) is an internal command. Do not call directly.
replSetFresh
replSetFresh
replSetFresh (page 378) is an internal command that supports replica set functionality.
transferMods
_transferMods
_transferMods (page 378) is an internal command. Do not call directly.
handshake
handshake
handshake (page 378) is an internal command.
378 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
mapreduce.shardednish
mapreduce.shardedfinish
Provides internal functionality to support map-reduce in sharded environments.
See also:
mapReduce (page 218)
replSetElect
replSetElect
replSetElect (page 379) is an internal command that support replica set functionality.
replSetGetRBID
replSetGetRBID
replSetGetRBID (page 379) is an internal command that supports replica set functionality.
replSetHeartbeat
replSetHeartbeat
replSetHeartbeat (page 379) is an internal command that supports replica set functionality.
writeBacksQueued
writeBacksQueued
writeBacksQueued (page 379) is an internal command that returns a document reporting there are opera-
tions in the write back queue for the given mongos (page 571) and information about the queues.
writeBacksQueued.hasOpsQueued
Boolean.
hasOpsQueued (page 379) is true if there are write Back operations queued.
writeBacksQueued.totalOpsQueued
Integer.
totalOpsQueued (page 379) reects the number of operations queued.
writeBacksQueued.queues
Document.
queues (page 379) holds a sub-document where the elds are all write back queues. These eld hold a
document with two elds that reports on the state of the queue. The elds in these documents are:
writeBacksQueued.queues.n
n (page 379) reects the size, by number of items, in the queues.
writeBacksQueued.queues.minutesSinceLastCall
The number of minutes since the last time the mongos (page 571) touched this queue.
The command document has the following prototype form:
{writeBacksQueued: 1}
2.2. Database Commands 379
MongoDB Reference Manual, Release 2.6.4
To call writeBacksQueued (page 379) from the mongo (page 580) shell, use the following
db.runCommand() (page 124) form:
db.runCommand({writeBacksQueued: 1})
Consider the following example output:
{
"hasOpsQueued" : true,
"totalOpsQueued" : 7,
"queues" : {
"50b4f09f6671b11ff1944089" : { "n" : 0, "minutesSinceLastCall" : 1 },
"50b4f09fc332bf1c5aeaaf59" : { "n" : 0, "minutesSinceLastCall" : 0 },
"50b4f09f6671b1d51df98cb6" : { "n" : 0, "minutesSinceLastCall" : 0 },
"50b4f0c67ccf1e5c6effb72e" : { "n" : 0, "minutesSinceLastCall" : 0 },
"50b4faf12319f193cfdec0d1" : { "n" : 0, "minutesSinceLastCall" : 4 },
"50b4f013d2c1f8d62453017e" : { "n" : 0, "minutesSinceLastCall" : 0 },
"50b4f0f12319f193cfdec0d1" : { "n" : 0, "minutesSinceLastCall" : 1 }
},
"ok" : 1
}
writebacklisten
writebacklisten
writebacklisten (page 380) is an internal command.
2.2.4 Testing Commands
Testing Commands
Name Description
_hashBSONElement
(page 380)
Internal command. Computes the MD5 hash of a BSON element.
_journalLatencyTest Tests the time required to write and perform a le system sync for a le in the
journal directory.
captrunc (page 382) Internal command. Truncates capped collections.
configureFailPoint
(page 383)
Internal command for testing. Congures failure points.
emptycapped (page 383) Internal command. Removes all documents from a capped collection.
forceerror (page 383) Internal command for testing. Forces a user assertion exception.
godinsert (page 384) Internal command for testing.
replSetTest (page 384) Internal command for testing replica set functionality.
skewClockCommand Internal command. Do not call this command directly.
sleep (page 384) Internal command for testing. Forces MongoDB to block all operations.
testDistLockWithSkew Internal command. Do not call this directly.
testDistLockWithSyncCluster Internal command. Do not call this directly.
_hashBSONElement
Description
380 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
_hashBSONElement
New in version 2.4.
An internal command that computes the MD5 hash of a BSON element. The _hashBSONElement (page 380)
command returns 8 bytes from the 16 byte MD5 hash.
The _hashBSONElement (page 380) command has the following form:
db.runCommand({ _hashBSONElement: <key> , seed: <seed> })
The _hashBSONElement (page 380) command has the following elds:
eld BSONElement key The BSON element to hash.
eld integer seed A seed used when computing the hash.
Note: _hashBSONElement (page 380) is an internal command that is not enabled by
default. _hashBSONElement (page 380) must be enabled by using --setParameter
enableTestCommands=1 on the mongod (page 555) command line. _hashBSONElement (page 380)
cannot be enabled during run-time.
Output The _hashBSONElement (page 380) command returns a document that holds the following elds:
_hashBSONElement.key
The original BSON element.
_hashBSONElement.seed
The seed used for the hash, defaults to 0.
_hashBSONElement.out
The decimal result of the hash.
_hashBSONElement.ok
Holds the 1 if the function returns successfully, and 0 if the operation encountered an error.
Example Invoke a mongod (page 555) instance with test commands enabled:
mongod --setParameter enableTestCommands=1
Run the following to compute the hash of an ISODate string:
db.runCommand({_hashBSONElement: ISODate("2013-02-12T22:12:57.211Z")})
The command returns the following document:
{
"key" : ISODate("2013-02-12T22:12:57.211Z"),
"seed" : 0,
"out" : NumberLong("-4185544074338741873"),
"ok" : 1
}
Run the following to hash the same ISODate string but this time to specify a seed value:
db.runCommand({_hashBSONElement: ISODate("2013-02-12T22:12:57.211Z"), seed:2013})
The command returns the following document:
2.2. Database Commands 381
MongoDB Reference Manual, Release 2.6.4
{
"key" : ISODate("2013-02-12T22:12:57.211Z"),
"seed" : 2013,
"out" : NumberLong("7845924651247493302"),
"ok" : 1
}
journalLatencyTest
journalLatencyTest
journalLatencyTest (page 382) is an administrative command that tests the length of time required
to write and perform a le system sync (e.g. fsync) for a le in the journal directory. You must issue the
journalLatencyTest (page 382) command against the admin database in the form:
{ journalLatencyTest: 1 }
The value (i.e. 1 above), does not affect the operation of the command.
Note: journalLatencyTest (page 382) is an internal command that is not enabled by
default. journalLatencyTest (page 382) must be enabled by using --setParameter
enableTestCommands=1 on the mongod (page 555) command line. journalLatencyTest (page 382)
cannot be enabled during run-time.
captrunc
Denition
captrunc
captrunc (page 382) is a command that truncates capped collections for diagnostic and testing purposes and
is not part of the stable client facing API. The command takes the following form:
{ captrunc: "<collection>", n: <integer>, inc: <true|false> }.
captrunc (page 382) has the following elds:
eld string captrunc The name of the collection to truncate.
eld integer n The number of documents to remove from the collection.
eld boolean inc Species whether to truncate the nth document.
Note: captrunc (page 382) is an internal command that is not enabled by default. captrunc (page 382) must
be enabled by using --setParameter enableTestCommands=1 on the mongod (page 555) command line.
captrunc (page 382) cannot be enabled during run-time.
Examples The following command truncates 10 older documents from the collection records:
db.runCommand({captrunc: "records" , n: 10})
The following command truncates 100 documents and the 101st document:
db.runCommand({captrunc: "records", n: 100, inc: true})
382 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
congureFailPoint
Denition
configureFailPoint
Congures a failure point that you can turn on and off while MongoDB runs. configureFailPoint
(page 383) is an internal command for testing purposes that takes the following form:
{configureFailPoint: "<failure_point>", mode: <behavior> }
You must issue configureFailPoint (page 383) against the admin database. configureFailPoint
(page 383) has the following elds:
eld string congureFailPoint The name of the failure point.
eld document,string mode Controls the behavior of a failure point. The possible values are
alwaysOn, off, or a document in the form of {times: n} that species the number of
times the failure point remains on before it deactivates. The maximum value for the number is a
32-bit signed integer.
eld document data Passes in additional data for use in conguring the fail point. For example, to
imitate a slow connection pass in a document that contains a delay time.
Note: configureFailPoint (page 383) is an internal command that is not enabled by default.
configureFailPoint (page 383) must be enabled by using --setParameter enableTestCommands=1
on the mongod (page 555) command line. configureFailPoint (page 383) cannot be enabled during run-time.
Example
db.adminCommand( { configureFailPoint: "blocking_thread", mode: {times: 21} } )
emptycapped
emptycapped
The emptycapped command removes all documents from a capped collection. Use the following syntax:
{ emptycapped: "events" }
This command removes all records from the capped collection named events.
Warning: This command obtains a write lock on the affected database and will block other operations until
it has completed.
Note: emptycapped (page 383) is an internal command that is not enabled by default. emptycapped
(page 383) must be enabled by using --setParameter enableTestCommands=1 on the mongod
(page 555) command line. emptycapped (page 383) cannot be enabled during run-time.
forceerror
forceerror
The forceerror (page 383) command is for testing purposes only. Use forceerror (page 383) to force a
user assertion exception. This command always returns an ok value of 0.
2.2. Database Commands 383
MongoDB Reference Manual, Release 2.6.4
godinsert
godinsert
godinsert (page 384) is an internal command for testing purposes only.
Note: This command obtains a write lock on the affected database and will block other operations until it has
completed.
Note: godinsert (page 384) is an internal command that is not enabled by default. godinsert (page 384)
must be enabled by using --setParameter enableTestCommands=1 on the mongod (page 555) com-
mand line. godinsert (page 384) cannot be enabled during run-time.
replSetTest
replSetTest
replSetTest (page 384) is internal diagnostic command used for regression tests that supports replica set
functionality.
Note: replSetTest (page 384) is an internal command that is not enabled by default. replSetTest
(page 384) must be enabled by using --setParameter enableTestCommands=1 on the mongod
(page 555) command line. replSetTest (page 384) cannot be enabled during run-time.
skewClockCommand
_skewClockCommand
_skewClockCommand (page 384) is an internal command. Do not call directly.
Note: _skewClockCommand (page 384) is an internal command that is not enabled by
default. _skewClockCommand (page 384) must be enabled by using --setParameter
enableTestCommands=1 on the mongod (page 555) command line. _skewClockCommand (page 384)
cannot be enabled during run-time.
sleep
Denition
sleep
Forces the database to block all operations. This is an internal command for testing purposes.
The sleep (page 384) command takes the following prototype form:
{ sleep: 1, w: <true|false>, secs: <seconds> }
The sleep (page 384) command has the following elds:
eld boolean w If true, obtains a global write lock. Otherwise obtains a read lock.
eld integer secs The number of seconds to sleep.
384 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Behavior The command places the mongod (page 555) instance in a write lock state for 100 seconds. Without
arguments, sleep (page 384) causes a read lock for 100 seconds.
Warning: sleep (page 384) claims the lock specied in the w argument and blocks all operations on the mongod
(page 555) instance for the specied amount of time.
Note: sleep (page 384) is an internal command that is not enabled by default. sleep (page 384) must be enabled
by using --setParameter enableTestCommands=1 on the mongod (page 555) command line. sleep
(page 384) cannot be enabled during run-time.
testDistLockWithSkew
_testDistLockWithSkew
_testDistLockWithSkew (page 385) is an internal command. Do not call directly.
Note: _testDistLockWithSkew (page 385) is an internal command that is not enabled by
default. _testDistLockWithSkew (page 385) must be enabled by using --setParameter
enableTestCommands=1 on the mongod (page 555) command line. _testDistLockWithSkew
(page 385) cannot be enabled during run-time.
testDistLockWithSyncCluster
_testDistLockWithSyncCluster
_testDistLockWithSyncCluster (page 385) is an internal command. Do not call directly.
Note: _testDistLockWithSyncCluster (page 385) is an internal command that is not
enabled by default. _testDistLockWithSyncCluster (page 385) must be enabled by us-
ing --setParameter enableTestCommands=1 on the mongod (page 555) command line.
_testDistLockWithSyncCluster (page 385) cannot be enabled during run-time.
2.2.5 Auditing Commands
System Events Auditing Commands
Name Description
logApplicationMessage (page 385) Posts a custom message to the audit log.
logApplicationMessage
logApplicationMessage
The logApplicationMessage (page 385) command allows users to post a custom message to the au-
dit log. If running with authorization, users must have clusterAdmin role, or roles that inherit from
clusterAdmin, to run the command.
Note: The audit system is available only in MongoDB Enterprise
20
.
20
http://www.mongodb.com/products/mongodb-enterprise
2.2. Database Commands 385
MongoDB Reference Manual, Release 2.6.4
The logApplicationMessage (page 385) has the following syntax:
{ logApplicationMessage: <string> }
MongoDB associates these custom messages with the audit operation applicationMessage, and the mes-
sages are subject to any ltering.
2.3 Operators
Query and Projection Operators (page 386) Query operators provide ways to locate data within the database and
projection operators modify how data is presented.
Update Operators (page 429) Update operators are operators that enable you to modify the data in your database or
add additional data.
Aggregation Pipeline Operators (page 456) Aggregation pipeline operations have a collection of operators available
to dene and manipulate documents in pipeline stages.
Query Modiers (page 528) Query modiers determine the way that queries will be executed.
2.3.1 Query and Projection Operators
Query Selectors
Comparison
Comparison Query Operators For comparison of different BSON type values, see the specied BSON comparison
order.
Name Description
$gt (page 386) Matches values that are greater than the value specied in the query.
$gte (page 387) Matches values that are greater than or equal to the value specied in the query.
$in (page 387) Matches any of the values that exist in an array specied in the query.
$lt (page 388) Matches values that are less than the value specied in the query.
$lte (page 389) Matches values that are less than or equal to the value specied in the query.
$ne (page 389) Matches all values that are not equal to the value specied in the query.
$nin (page 390) Matches values that do not exist in an array specied to the query.
$gt
$gt
Syntax: {field: {$gt: value} }
$gt (page 386) selects those documents where the value of the field is greater than (i.e. >) the specied
value.
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following example:
db.inventory.find( { qty: { $gt: 20 } } )
This query will select all documents in the inventory collection where the qty eld value is greater than
20.
Consider the following example that uses the $gt (page 386) operator with a eld from an embedded document:
386 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.inventory.update( { "carrier.fee": { $gt: 2 } }, { $set: { price: 9.99 } } )
This update() (page 70) operation will set the value of the price eld in the rst document found containing
the embedded document carrier whose fee eld value is greater than 2.
To set the value of the price eld in all documents containing the embedded document carrier whose fee
eld value is greater than 2, specify the multi:true option in the update() (page 70) method:
db.inventory.update( { "carrier.fee": { $gt: 2 } },
{ $set: { price: 9.99 },
{ multi: true }
)
See also:
find() (page 33), update() (page 70), $set (page 436).
$gte
$gte
Syntax: {field: {$gte: value} }
$gte (page 387) selects the documents where the value of the field is greater than or equal to (i.e. >=) a
specied value (e.g. value.)
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following example:
db.inventory.find( { qty: { $gte: 20 } } )
This query would select all documents in inventory where the qty eld value is greater than or equal to 20.
Consider the following example which uses the $gte (page 387) operator with a eld from an embedded
document:
db.inventory.update( { "carrier.fee": { $gte: 2 } }, { $set: { price: 9.99 } } )
This update() (page 70) operation will set the value of the price eld that contain the embedded document
carrier whose fee eld value is greater than or equal to 2.
See also:
find() (page 33), update() (page 70), $set (page 436).
$in
$in
The $in (page 387) operator selects the documents where the value of a eld equals any value in the specied
array. To specify an $in (page 387) expression, use the following prototype:
For comparison of different BSON type values, see the specied BSON comparison order.
{ field: { $in: [<value1>, <value2>, ... <valueN> ] } }
If the field holds an array, then the $in (page 387) operator selects the documents whose field holds an
array that contains at least one element that matches a value in the specied array (e.g. <value1>, <value2>,
etc.)
Changed in version 2.6: MongoDB 2.6 removes the combinatorial limit for the $in (page 387) operator that
exists for earlier versions
21
of the operator.
21
http://docs.mongodb.org/v2.4/reference/operator/query/in
2.3. Operators 387
MongoDB Reference Manual, Release 2.6.4
Examples
Use the $in Operator to Match Values Consider the following example:
db.inventory.find( { qty: { $in: [ 5, 15 ] } } )
This query selects all documents in the inventory collection where the qty eld value is either 5 or 15. Although
you can express this query using the $or (page 393) operator, choose the $in (page 387) operator rather than the
$or (page 393) operator when performing equality checks on the same eld.
Use the $in Operator to Match Values in an Array The collection inventory contains documents that include
the eld tags, as in the following:
{ _id: 1, item: "abc", qty: 10, tags: [ "school", "clothing" ], sale: false }
Then, the following update() (page 70) operation will set the sale eld value to true where the tags eld holds
an array with at least one element matching either "appliances" or "school".
db.inventory.update(
{ tags: { $in: ["appliances", "school"] } },
{ $set: { sale:true } }
)
Use the $in Operator with a Regular Expression The $in (page 387) operator can specify matching values using
regular expressions of the form http://docs.mongodb.org/manualpattern/. You cannot use $regex
(page 399) operator expressions inside an $in (page 387).
Consider the following example:
db.inventory.find( { tags: { $in: [ /^be/, /^st/ ] } } )
This query selects all documents in the inventory collection where the tags eld holds an array that contains at
least one element that starts with either be or st.
See also:
find() (page 33), update() (page 70), $or (page 393), $set (page 436).
$lt
$lt
Syntax: {field: {$lt: value} }
$lt (page 388) selects the documents where the value of the field is less than (i.e. <) the specied value.
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following example:
db.inventory.find( { qty: { $lt: 20 } } )
This query will select all documents in the inventory collection where the qty eld value is less than 20.
Consider the following example which uses the $lt (page 388) operator with a eld from an embedded docu-
ment:
db.inventory.update( { "carrier.fee": { $lt: 20 } }, { $set: { price: 9.99 } } )
388 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
This update() (page 70) operation will set the price eld value in the documents that contain the embedded
document carrier whose fee eld value is less than 20.
See also:
find() (page 33), update() (page 70), $set (page 436).
$lte
$lte
Syntax: { field: { $lte: value} }
$lte (page 389) selects the documents where the value of the field is less than or equal to (i.e. <=) the
specied value.
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following example:
db.inventory.find( { qty: { $lte: 20 } } )
This query will select all documents in the inventory collection where the qty eld value is less than or
equal to 20.
Consider the following example which uses the $lt (page 388) operator with a eld from an embedded docu-
ment:
db.inventory.update( { "carrier.fee": { $lte: 5 } }, { $set: { price: 9.99 } } )
This update() (page 70) operation will set the price eld value in the documents that contain the embedded
document carrier whose fee eld value is less than or equal to 5.
See also:
find() (page 33), update() (page 70), $set (page 436).
$ne
$ne
Syntax: {field: {$ne: value} }
$ne (page 389) selects the documents where the value of the field is not equal (i.e. !=) to the specied
value. This includes documents that do not contain the field.
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following example:
db.inventory.find( { qty: { $ne: 20 } } )
This query will select all documents in the inventory collection where the qty eld value does not equal
20, including those documents that do not contain the qty eld.
Consider the following example which uses the $ne (page 389) operator with a eld in an embedded document:
db.inventory.update( { "carrier.state": { $ne: "NY" } }, { $set: { qty: 20 } } )
This update() (page 70) operation will set the qty eld value in the documents that contain the embedded
document carrier whose state eld value does not equal NY, or where the state eld or the carrier
embedded document do not exist.
See also:
find() (page 33), update() (page 70), $set (page 436).
2.3. Operators 389
MongoDB Reference Manual, Release 2.6.4
$nin
$nin
Syntax: { field: { $nin: [ <value1>, <value2> ... <valueN> ]} }
$nin (page 390) selects the documents where:
the field value is not in the specied array or
the field does not exist.
For comparison of different BSON type values, see the specied BSON comparison order.
Consider the following query:
db.inventory.find( { qty: { $nin: [ 5, 15 ] } } )
This query will select all documents in the inventory collection where the qty eld value does not equal 5
nor 15. The selected documents will include those documents that do not contain the qty eld.
If the field holds an array, then the $nin (page 390) operator selects the documents whose field holds an
array with no element equal to a value in the specied array (e.g. <value1>, <value2>, etc.).
Consider the following query:
db.inventory.update( { tags: { $nin: [ "appliances", "school" ] } }, { $set: { sale: false } } )
This update() (page 70) operation will set the sale eld value in the inventory collection where
the tags eld holds an array with no elements matching an element in the array ["appliances",
"school"] or where a document does not contain the tags eld.
See also:
find() (page 33), update() (page 70), $set (page 436).
Logical
Logical Query Operators
Name Description
$and
(page 390)
Joins query clauses with a logical AND returns all documents that match the conditions of both
clauses.
$nor
(page 391)
Joins query clauses with a logical NOR returns all documents that fail to match both clauses.
$not
(page 392)
Inverts the effect of a query expression and returns documents that do not match the query
expression.
$or (page 393) Joins query clauses with a logical OR returns all documents that match the conditions of either
clause.
$and
$and
New in version 2.0.
Syntax: { $and: [ { <expression1> }, { <expression2> } , ... , {
<expressionN> } ] }
$and (page 390) performs a logical AND operation on an array of two or more expressions (e.g.
<expression1>, <expression2>, etc.) and selects the documents that satisfy all the expressions
in the array. The $and (page 390) operator uses short-circuit evaluation. If the rst expression (e.g.
<expression1>) evaluates to false, MongoDB will not evaluate the remaining expressions.
Note: MongoDB provides an implicit AND operation when specifying a comma separated list of expressions.
390 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Using an explicit AND with the $and (page 390) operator is necessary when the same eld or operator has to
be specied in multiple expressions.
Examples
AND Queries With Multiple Expressions Specifying the Same Field Consider the following example:
db.inventory.find( { $and: [ { price: { $ne: 1.99 } }, { price: { $exists: true } } ] } )
This query will select all documents in the inventory collection where:
the price eld value is not equal to 1.99 and
the price eld exists.
This query can be also be constructed with an implicit AND operation by combining the operator expressions for the
price eld. For example, this query can be written as:
db.inventory.find( { price: { $ne: 1.99, $exists: true } } )
AND Queries With Multiple Expressions Specifying the Same Operator Consider the following example:
db.inventory.find( {
$and : [
{ $or : [ { price : 0.99 }, { price : 1.99 } ] },
{ $or : [ { sale : true }, { qty : { $lt : 20 } } ] }
]
} )
This query will return all select all documents where:
the price eld value equals 0.99 or 1.99, and
the sale eld value is equal to true or the qty eld value is less than 20.
This query cannot be constructed using an implicit AND operation, because it uses the $or (page 393) operator more
than once.
See also:
find() (page 33), update() (page 70), $ne (page 389), $exists (page 395), $set (page 436).
$nor
$nor
$nor (page 391) performs a logical NOR operation on an array of one or more query expression and selects the
documents that fail all the query expressions in the array. The $nor (page 391) has the following syntax:
{ $nor: [ { <expression1> }, { <expression2> }, ... { <expressionN> } ] }
See also:
find() (page 33), update() (page 70), $or (page 393), $set (page 436), and $exists (page 395).
Examples
2.3. Operators 391
MongoDB Reference Manual, Release 2.6.4
$nor Query with Two Expressions Consider the following query which uses only the $nor (page 391) operator:
db.inventory.find( { $nor: [ { price: 1.99 }, { sale: true } ] } )
This query will return all documents that:
contain the price eld whose value is not equal to 1.99 and contain the sale eld whose value is not equal
to true or
contain the price eld whose value is not equal to 1.99 but do not contain the sale eld or
do not contain the price eld but contain the sale eld whose value is not equal to true or
do not contain the price eld and do not contain the sale eld
$nor and Additional Comparisons Consider the following query:
db.inventory.find( { $nor: [ { price: 1.99 }, { qty: { $lt: 20 } }, { sale: true } ] } )
This query will select all documents in the inventory collection where:
the price eld value does not equal 1.99 and
the qty eld value is not less than 20 and
the sale eld value is not equal to true
including those documents that do not contain these eld(s).
The exception in returning documents that do not contain the eld in the $nor (page 391) expression is when the
$nor (page 391) operator is used with the $exists (page 395) operator.
$nor and $exists Compare that with the following query which uses the $nor (page 391) operator with the
$exists (page 395) operator:
db.inventory.find( { $nor: [ { price: 1.99 }, { price: { $exists: false } },
{ sale: true }, { sale: { $exists: false } } ] } )
This query will return all documents that:
contain the price eld whose value is not equal to 1.99 and contain the sale eld whose value is not equal
to true
$not
$not
Syntax: { field: { $not: { <operator-expression> } } }
$not (page 392) performs a logical NOT operation on the specied <operator-expression> and selects
the documents that do not match the <operator-expression>. This includes documents that do not
contain the field.
Consider the following query:
db.inventory.find( { price: { $not: { $gt: 1.99 } } } )
This query will select all documents in the inventory collection where:
the price eld value is less than or equal to 1.99 or
the price eld does not exist
392 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ $not: { $gt: 1.99 } } is different from the $lte (page 389) operator. { $lte: 1.99 }
returns only the documents where price eld exists and its value is less than or equal to 1.99.
Remember that the $not (page 392) operator only affects other operators and cannot check elds and docu-
ments independently. So, use the $not (page 392) operator for logical disjunctions and the $ne (page 389)
operator to test the contents of elds directly.
Consider the following behaviors when using the $not (page 392) operator:
The operation of the $not (page 392) operator is consistent with the behavior of other operators but may
yield unexpected results with some data types like arrays.
The $not (page 392) operator does not support operations with the $regex (page 399) operator. Instead
use http://docs.mongodb.org/manual/ or in your driver interfaces, use your languages regular
expression capability to create regular expression objects.
Consider the following example which uses the pattern match expression
http://docs.mongodb.org/manual/:
db.inventory.find( { item: { $not: /^p.
*
/ } } )
The query will select all documents in the inventory collection where the item eld value does not
start with the letter p.
If you are using Python, you can write the above query with the PyMongo driver and Pythons
python:re.compile() method to compile a regular expression, as follows:
import re
for noMatch in db.inventory.find( { "item": { "$not": re.compile("^p.
*
") } } ):
print noMatch
See also:
find() (page 33), update() (page 70), $set (page 436), $gt (page 386), $regex (page 399), Py-
Mongo
22
, driver.
$or
$or
The $or (page 393) operator performs a logical OR operation on an array of two or more <expressions>
and selects the documents that satisfy at least one of the <expressions>. The $or (page 393) has the
following syntax:
{ $or: [ { <expression1> }, { <expression2> }, ... , { <expressionN> } ] }
Consider the following example:
db.inventory.find( { $or: [ { quantity: { $lt: 20 } }, { price: 10 } ] } )
This query will select all documents in the inventory collection where either the quantity eld value is
less than 20 or the price eld value equals 10.
Behaviors
$or Clauses and Indexes When evaluating the clauses in the $or (page 393) expression, MongoDBeither performs
a collection scan or, if all the clauses are supported by indexes, MongoDBperforms index scans. That is, for MongoDB
to use indexes to evaluate an $or (page 393) expression, all the clauses in the $or (page 393) expression must be
supported by indexes. Otherwise, MongoDB will perform a collection scan.
22
http://api.mongodb.org/pythoncurrent
2.3. Operators 393
MongoDB Reference Manual, Release 2.6.4
When using indexes with $or (page 393) queries, each clause of an $or (page 393) can use its own index. Consider
the following query:
db.inventory.find( { $or: [ { quantity: { $lt: 20 } }, { price: 10 } ] } )
To support this query, rather than a compound index, you would create one index on quantity and another index on
price:
db.inventory.ensureIndex( { quantity: 1 } )
db.inventory.ensureIndex( { price: 1 } )
MongoDB can use all but the geoHaystack index to support $or (page 393) clauses.
$or and text Queries Changed in version 2.6.
If $or (page 393) includes a $text (page 401) query, all clauses in the $or (page 393) array must be supported by
an index. This is because a $text (page 401) query must use an index, and $or (page 393) can only use indexes if
all its clauses are supported by indexes. If the $text (page 401) query cannot use an index, the query will return an
error.
$or and GeoSpatial Queries Changed in version 2.6.
$or (page 393) supports geospatial clauses (page 406) with the following exception for the near clause (near clause
includes $nearSphere (page 408) and $near (page 410)). $or (page 393) cannot contain a near clause with any
other clause.
$or and Sort Operations Changed in version 2.6.
When executing $or (page 393) queries with a sort() (page 96), MongoDB can now use indexes that support the
$or (page 393) clauses. Previous versions did not use the indexes.
$or versus $in When using $or (page 393) with <expressions> that are equality checks for the value of the
same eld, use the $in (page 387) operator instead of the $or (page 393) operator.
For example, to select all documents in the inventory collection where the quantity eld value equals either 20
or 50, use the $in (page 387) operator:
db.inventory.find ( { quantity: { $in: [20, 50] } } )
Nested $or Clauses You may nest $or (page 393) operations.
See also:
$and (page 390), find() (page 33), sort() (page 96), $in (page 387)
Element
Element Query Operators
Name Description
$exists (page 395) Matches documents that have the specied eld.
$type (page 396) Selects documents if a eld is of the specied type.
$exists
394 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Denition
$exists
Syntax: { field: { $exists: <boolean> } }
When <boolean> is true, $exists (page 395) matches the documents that contain the eld, including
documents where the eld value is null. If <boolean> is false, the query returns only the documents that do
not contain the eld.
MongoDB $exists does not correspond to SQL operator exists. For SQL exists, refer to the $in
(page 387) operator.
See also:
$nin (page 390), $in (page 387), and faq-developers-query-for-nulls.
Examples
Exists and Not Equal To Consider the following example:
db.inventory.find( { qty: { $exists: true, $nin: [ 5, 15 ] } } )
This query will select all documents in the inventory collection where the qty eld exists and its value does not
equal 5 or 15.
Null Values Given a collection named records with the following documents:
{ a: 5, b: 5, c: null }
{ a: 3, b: null, c: 8 }
{ a: null, b: 3, c: 9 }
{ a: 1, b: 2, c: 3 }
{ a: 2, c: 5 }
{ a: 3, b: 2 }
{ a: 4 }
{ b: 2, c: 4 }
{ b: 2 }
{ c: 6 }
Consider the output of the following queries:
Query:
db.records.find( { a: { $exists: true } } )
Result:
{ a: 5, b: 5, c: null }
{ a: 3, b: null, c: 8 }
{ a: null, b: 3, c: 9 }
{ a: 1, b: 2, c: 3 }
{ a: 2, c: 5 }
{ a: 3, b: 2 }
{ a: 4 }
Query:
db.records.find( { b: { $exists: false } } )
Result:
2.3. Operators 395
MongoDB Reference Manual, Release 2.6.4
{ a: 2, c: 5 }
{ a: 4 }
{ c: 6 }
Query:
db.records.find( { c: { $exists: false } } )
Result:
{ a: 3, b: 2 }
{ a: 4 }
{ b: 2 }
$type
$type
Syntax: { field: { $type: <BSON type> } }
$type (page 396) selects the documents where the value of the field is the specied BSON type.
Consider the following example:
db.inventory.find( { price: { $type : 1 } } )
This query will select all documents in the inventory collection where the price eld value is a Double.
If the field holds an array, the $type (page 396) operator performs the type check against the array elements
and not the field.
Consider the following example where the tags eld holds an array:
db.inventory.find( { tags: { $type : 4 } } )
This query will select all documents in the inventory collection where the tags array contains an element
that is itself an array.
If instead you want to determine whether the tags eld is an array type, use the $where (page 404) operator:
db.inventory.find( { $where : "Array.isArray(this.tags)" } )
See the SERVER-1475
23
for more information about the array type.
Refer to the following table for the available BSON types and their corresponding numbers.
23
https://jira.mongodb.org/browse/SERVER-1475
396 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Type Number
Double 1
String 2
Object 3
Array 4
Binary data 5
Undened (deprecated) 6
Object id 7
Boolean 8
Date 9
Null 10
Regular Expression 11
JavaScript 13
Symbol 14
JavaScript (with scope) 15
32-bit integer 16
Timestamp 17
64-bit integer 18
Min key 255
Max key 127
MinKey and MaxKey compare less than and greater than all other possible BSON element values, respectively,
and exist primarily for internal use.
Note: To query if a eld value is a MinKey, you must use the $type (page 396) with -1 as in the following
example:
db.collection.find( { field: { $type: -1 } } )
Example
Consider the following example operation sequence that demonstrates both type comparison and the special
MinKey and MaxKey values:
db.test.insert( {x : 3});
db.test.insert( {x : 2.9} );
db.test.insert( {x : new Date()} );
db.test.insert( {x : true } );
db.test.insert( {x : MaxKey } )
db.test.insert( {x : MinKey } )
db.test.find().sort({x:1})
{ "_id" : ObjectId("4b04094b7c65b846e2090112"), "x" : { $minKey : 1 } }
{ "_id" : ObjectId("4b03155dce8de6586fb002c7"), "x" : 2.9 }
{ "_id" : ObjectId("4b03154cce8de6586fb002c6"), "x" : 3 }
{ "_id" : ObjectId("4b031566ce8de6586fb002c9"), "x" : true }
{ "_id" : ObjectId("4b031563ce8de6586fb002c8"), "x" : "Tue Jul 25 2012 18:42:03 GMT-0500 (EST)" }
{ "_id" : ObjectId("4b0409487c65b846e2090111"), "x" : { $maxKey : 1 } }
To query for the minimum value of a shard key of a sharded cluster, use the following operation when connected
to the mongos (page 571):
use config
db.chunks.find( { "min.shardKey": { $type: -1 } } )
Warning: Storing values of the different types in the same eld in a collection is strongly discouraged.
2.3. Operators 397
MongoDB Reference Manual, Release 2.6.4
See also:
find() (page 33), insert() (page 53), $where (page 404), BSON, shard key, sharded cluster .
Evaluation
Evaluation Query Operators
Name Description
$mod (page 398) Performs a modulo operation on the value of a eld and selects documents with a specied
result.
$regex
(page 399)
Selects documents where values match a specied regular expression.
$text (page 401) Performs text search.
$where
(page 404)
Matches documents that satisfy a JavaScript expression.
$mod
$mod
Select documents where the value of a eld divided by a divisor has the specied remainder (i.e. perform a
modulo operation to select documents). To specify a $mod (page 398) expression, use the following syntax:
{ field: { $mod: [ divisor, remainder ] } }
Changed in version 2.6: The $mod (page 398) operator errors when passed an array with fewer or more ele-
ments. In previous versions, if passed an array with one element, the $mod (page 398) operator uses 0 as the
remainder value, and if passed an array with more than two elements, the $mod (page 398) ignores all but the
rst two elements. Previous versions do return an error when passed an empty array. See Not Enough Elements
Error (page 398) and Too Many Elements Error (page 399) for details.
Examples
Use $mod to Select Documents Consider a collection inventory with the following documents:
{ "_id" : 1, "item" : "abc123", "qty" : 0 }
{ "_id" : 2, "item" : "xyz123", "qty" : 5 }
{ "_id" : 3, "item" : "ijk123", "qty" : 12 }
Then, the following query selects those documents in the inventory collection where value of the qty eld modulo
4 equals 0:
db.inventory.find( { qty: { $mod: [ 4, 0 ] } } )
The query returns the following documents:
{ "_id" : 1, "item" : "abc123", "qty" : 0 }
{ "_id" : 3, "item" : "ijk123", "qty" : 12 }
Not Enough Elements Error The $mod (page 398) operator errors when passed an array with fewer than two
elements.
398 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Array with Single Element The following operation incorrectly passes the $mod (page 398) operator an array that
contains a single element:
db.inventory.find( { qty: { $mod: [ 4 ] } } )
The statement results in the following error:
error: {
"$err" : "bad query: BadValue malformed mod, not enough elements",
"code" : 16810
}
Changed in version 2.6: In previous versions, if passed an array with one element, the $mod (page 398) operator uses
the specied element as the divisor and 0 as the remainder value.
Empty Array The following operation incorrectly passes the $mod (page 398) operator an empty array:
db.inventory.find( { qty: { $mod: [ ] } } )
The statement results in the following error:
error: {
"$err" : "bad query: BadValue malformed mod, not enough elements",
"code" : 16810
}
Changed in version 2.6: Previous versions returned the following error:
error: { "$err" : "mod can't be 0", "code" : 10073 }
Too Many Elements Error The $mod (page 398) operator errors when passed an array with more than two ele-
ments.
For example, the following operation attempts to use the $mod (page 398) operator with an array that contains four
elements:
error: {
"$err" : "bad query: BadValue malformed mod, too many elements",
"code" : 16810
}
Changed in version 2.6: In previous versions, if passed an array with more than two elements, the $mod (page 398)
ignores all but the rst two elements.
$regex
$regex
The $regex (page 399) operator provides regular expression capabilities for pattern matching strings in
queries. MongoDB uses Perl compatible regular expressions (i.e. PCRE.)
You can specify regular expressions using regular expression objects (i.e.
http://docs.mongodb.org/manualpattern/ ) or using the $regex (page 399) operator.
The following examples are equivalent:
db.collection.find( { field: /acme.
*
corp/i } );
db.collection.find( { field: { $regex: 'acme.
*
corp', $options: 'i' } } );
These expressions match all documents in collection where the value of field matches the case-
insensitive regular expression acme.
*
corp.
2.3. Operators 399
MongoDB Reference Manual, Release 2.6.4
$options
$regex (page 399) provides four option ags:
i toggles case insensitivity, and allows all letters in the pattern to match upper and lower cases.
m toggles multiline regular expression. Without this option, all regular expression match within one
line.
If there are no newline characters (e.g. \n) or no start/end of line construct, the m option has no effect.
x toggles an extended capability. When set, $regex (page 399) ignores all white space characters
unless escaped or included in a character class.
Additionally, it ignores characters between an un-escaped # character and the next new line, so that
you may include comments in complicated patterns. This only applies to data characters; white space
characters may never appear within special character sequences in a pattern.
The x option does not affect the handling of the VT character (i.e. code 11.)
s allows the dot (e.g. .) character to match all characters including newline characters.
Only the i and m options are available for the native JavaScript regular expression objects (e.g.
http://docs.mongodb.org/manualacme.
*
corp/i). To use x and s options, you must use
the $regex (page 399) operator with the $options (page 399) syntax.
To combine a regular expression match with other operators, you need to use the $regex (page 399) operator.
For example:
db.collection.find( { field: { $regex: /acme.
*
corp/i, $nin: [ 'acmeblahcorp' ] } } );
This expression returns all instances of field in collection that match the case insensitive regular expres-
sion acme.
*
corp that dont match acmeblahcorp.
Behavior
PCRE Matching Engine $regex (page 399) uses Perl Compatible Regular Expressions (PCRE) as the matching
engine.
$in Expressions To include a regular expression in an $in query expression, you can only use JavaScript reg-
ular expression objects (i.e. http://docs.mongodb.org/manualpattern/ ). You cannot use $regex
(page 399) operator expressions inside an $in (page 387).
Index Use If an index exists for the eld, then MongoDB matches the regular expression against the values in the
index, which can be faster than a collection scan. Further optimization can occur if the regular expression is a prex
expression, which means that all potential matches start with the same string. This allows MongoDB to construct a
range from that prex and only match against those values from the index that fall within that range.
A regular expression is a prex expression if it starts with a caret (^) or a left anchor (\A), followed by a string of
simple symbols. For example, the regex http://docs.mongodb.org/manual^abc.
*
/ will be optimized by
matching only against the values from the index that start with abc.
Additionally, while http://docs.mongodb.org/manual^a/, http://docs.mongodb.org/manual^a.
*
/,
and http://docs.mongodb.org/manual^a.
*
$/ match equivalent strings, they have different per-
formance characteristics. All of these expressions use an index if an appropriate index exists; however,
http://docs.mongodb.org/manual^a.
*
/, and http://docs.mongodb.org/manual^a.
*
$/
are slower. http://docs.mongodb.org/manual^a/ can stop scanning after matching the prex.
400 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
$text
$text
New in version 2.6.
$text (page 401) performs a text search on the content of the elds indexed with a text index. A $text
(page 401) expression has the following syntax:
{ $text: { $search: <string>, $language: <string> } }
The $text (page 401) operator accepts a text query document with the following elds:
eld string $search A string of terms that MongoDB parses and uses to query the text index. Mon-
goDB performs a logical OR search of the terms unless specied as a phrase. See Behavior
(page 401) for more information on the eld.
eld string $language The language that determines the list of stop words for the search and the
rules for the stemmer and tokenizer. If not specied, the search uses the default language of the
index. For supported languages, see text-search-languages.
If you specify a language value of "none", then the text search uses simple tokenization with
no list of stop words and no stemming.
The $text (page 401) operator, by default, does not return results sorted in terms of the results score. For
more information, see the Text Score (page 402) documentation.
Behavior
Restrictions
A query can specify, at most, one $text (page 401) expression.
The $text (page 401) query can not appear in $nor (page 391) expressions.
To use a $text (page 401) query in an $or (page 393) expression, all clauses in the $or (page 393) array
must be indexed.
You cannot use hint() (page 88) if the query includes a $text (page 401) query expression.
You cannot specify $natural (page 535) sort order if the query includes a $text (page 401) expression.
You cannot combine the $text (page 401) expression, which requires a special text index, with a query operator
that requires a different type of special index. For example you cannot combine $text (page 401) expression
with the $near (page 410) operator.
$search Field In the $search eld, specify a string of words that the text operator parses and uses to query
the text index. The text operator treats most punctuation in the string as delimiters, except a hyphen - that
negates term or an escaped double quotes \" that species a phrase.
Phrases To match on a phrase, as opposed to individual terms, enclose the phrase in escaped double quotes (\"), as
in:
"\"ssl certificate\""
If the $search string includes a phrase and individual terms, text search will only match the documents that include
the phrase. More specically, the search performs a logical AND of the phrase with the individual terms in the search
string.
For example, passed a $search string:
2.3. Operators 401
MongoDB Reference Manual, Release 2.6.4
"\"ssl certificate\" authority key"
The $text (page 401) operator searches for the phrase "ssl certificate" and ("authority" or "key"
or "ssl" or "certificate" ).
Negations Prexing a word with a hyphen sign (-) negates a word:
The negated word excludes documents that contain the negated word from the result set.
When passed a search string that only contains negated words, text search will not match any documents.
A hyphenated word, such as pre-market, is not a negation. The $text (page 401) operator treats the hyphen
as a delimiter.
The $text (page 401) operator adds all negations to the query with the logical AND operator.
Match Operation The $text (page 401) operator ignores language-specic stop words, such as the and and in
English.
The $text (page 401) operator matches on the complete stemmed word. So if a document eld contains the word
blueberry, a search on the term blue will not match. However, blueberry or blueberries will match.
For non-diacritics, text search is case insensitive; i.e. case insensitive for [A-z].
Text Score The $text (page 401) operator assigns a score to each document that contains the search term in
the indexed elds. The score represents the relevance of a document to a given text search query. The score can
be part of a sort() (page 96) method specication as well as part of the projection expression. The { $meta:
"textScore" } expression provides information on the processing of the $text (page 401) operation. See
$meta (page 427) projection operator for details on accessing the score for projection or sort.
Examples The following examples assume a collection articles that has a text index on the eld subject:
db.articles.ensureIndex( { subject: "text" } )
Search for a Single Word The following query searches for the term coffee:
db.articles.find( { $text: { $search: "coffee" } } )
This query returns documents that contain the term coffee in the indexed subject eld.
Match Any of the Search Terms If the search string is a space-delimited string, $text (page 401) operator per-
forms a logical OR search on each term and returns documents that contains any of the terms.
The following query searches species a $search string of three terms delimited by space, "bake coffee
cake":
db.articles.find( { $text: { $search: "bake coffee cake" } } )
This query returns documents that contain either bake or coffee or cake in the indexed subject eld.
402 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Search for a Phrase To match the exact phrase as a single term, escape the quotes.
The following query searches for the phrase coffee cake:
db.articles.find( { $text: { $search: "\"coffee cake\"" } } )
This query returns documents that contain the phrase coffee cake.
See also:
Phrases (page 401)
Exclude Documents That Contain a Term A negated term is a term that is prexed by a minus sign -. If you
negate a term, the $text (page 401) operator will exclude the documents that contain those terms from the results.
The following example searches for documents that contain the words bake or coffee but do not contain the term
cake:
db.articles.find( { $text: { $search: "bake coffee -cake" } } )
See also:
Negations (page 402)
Return the Text Search Score The following query searches for the term cake and returns the score assigned to
each matching document:
db.articles.find(
{ $text: { $search: "cake" } },
{ score: { $meta: "textScore" } }
)
In the result set, the returned documents includes an additional eld score that contains the documents score asso-
ciated with the text search.
24
See also:
Text Score (page 402)
Sort by Text Search Score To sort by the text score, include the same $meta (page 427) expression in both the
projection document and the sort expression.
1
The following query searches for the term cake and sorts the results
by the descending score:
db.articles.find(
{ $text: { $search: "cake" } },
{ score: { $meta: "textScore" } }
).sort( { score: { $meta: "textScore" } } )
In the result set, the returned documents includes an additional eld score that contains the documents score asso-
ciated with the text search.
See also:
Text Score (page 402)
24
The behavior and requirements of the $meta (page 427) operator differs from that of the $meta (page 503) aggregation operator. See the
$meta (page 503) aggregation operator for details.
2.3. Operators 403
MongoDB Reference Manual, Release 2.6.4
Return Top 3 Matching Documents Use the limit() (page 89) method in conjunction with a sort() (page 96)
to return the top three matching documents. The following query searches for the term cake and sorts the results by
the descending score:
db.articles.find(
{ $text: { $search: "cake" } },
{ score: { $meta: "textScore" } }
).sort( { score: { $meta: "textScore" } } ).limit(3)
See also:
Text Score (page 402)
Text Search with Additional Query and Sort Expressions The following query searches for documents with
status equal to "A" that contain the terms coffee or cake in the indexed eld subject and species a sort order
of ascending date, descending text score:
db.articles.find(
{ status: "A", $text: { $search: "coffee cake" } },
{ score: { $meta: "textScore" } }
).sort( { date: 1, score: { $meta: "textScore" } } )
Search a Different Language Use the optional $language eld in the $text (page 401) expression to specify a
language that determines the list of stop words and the rules for the stemmer and tokenizer for the search string.
If you specify a language value of "none", then the text search uses simple tokenization with no list of stop words
and no stemming.
The following query species es for Spanish as the language that determines the tokenization, stemming, and stop
words:
db.articles.find(
{ $text: { $search: "leche", $language: "es" } }
)
The $text (page 401) expression can also accept the language by name, spanish. See text-search-languages for
the supported languages.
See also:
http://docs.mongodb.org/manualtutorial/text-search-in-aggregation
$where
$where
Use the $where (page 404) operator to pass either a string containing a JavaScript expression or a full
JavaScript function to the query system. The $where (page 404) provides greater exibility, but requires
that the database processes the JavaScript expression or function for each document in the collection. Reference
the document in the JavaScript expression or function using either this or obj .
Behavior
Map Reduce Changed in version 2.4.
In MongoDB 2.4, map-reduce operations (page 218), the group (page 214) command, and $where
(page 404) operator expressions cannot access certain global functions or properties, such as db, that are available in
the mongo (page 580) shell.
404 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
When upgrading to MongoDB 2.4, you will need to refactor your code if your map-reduce operations
(page 218), group (page 214) commands, or $where (page 404) operator expressions include any global shell
functions or properties that are no longer available, such as db.
The following JavaScript functions and properties are available to map-reduce operations (page 218), the
group (page 214) command, and $where (page 404) operator expressions in MongoDB 2.4:
Available Properties Available Functions
args
MaxKey
MinKey
assert()
BinData()
DBPointer()
DBRef()
doassert()
emit()
gc()
HexData()
hex_md5()
isNumber()
isObject()
ISODate()
isString()
Map()
MD5()
NumberInt()
NumberLong()
ObjectId()
print()
printjson()
printjsononeline()
sleep()
Timestamp()
tojson()
tojsononeline()
tojsonObject()
UUID()
version()
elemMatch Changed in version 2.6.
Only apply the $where (page 404) query operator to top-level documents. The $where (page 404) query operator
will not work inside a nested document, for instance, in an $elemMatch (page 421) query.
Considerations
Do not write to the database within the $where (page 404) JavaScript function.
$where (page 404) evaluates JavaScript and cannot take advantage of indexes. Therefore, query performance
improves when you express your query using the standard MongoDB operators (e.g., $gt (page 386), $in
(page 387)).
In general, you should use $where (page 404) only when you cant express your query using another operator.
If you must use $where (page 404), try to include at least one other standard query operator to lter the result
set. Using $where (page 404) alone requires a table scan.
Using normal non-$where (page 404) query statements provides the following performance advantages:
MongoDB will evaluate non-$where (page 404) components of query before $where (page 404) statements.
If the non-$where (page 404) statements match no documents, MongoDB will not perform any query evalua-
tion using $where (page 404).
The non-$where (page 404) query statements may use an index.
Examples Consider the following examples:
2.3. Operators 405
MongoDB Reference Manual, Release 2.6.4
db.myCollection.find( { $where: "this.credits == this.debits" } );
db.myCollection.find( { $where: "obj.credits == obj.debits" } );
db.myCollection.find( { $where: function() { return (this.credits == this.debits) } } );
db.myCollection.find( { $where: function() { return obj.credits == obj.debits; } } );
Additionally, if the query consists only of the $where (page 404) operator, you can pass in just the JavaScript
expression or JavaScript functions, as in the following examples:
db.myCollection.find( "this.credits == this.debits || this.credits > this.debits" );
db.myCollection.find( function() { return (this.credits == this.debits || this.credits > this.debits ) } );
You can include both the standard MongoDB operators and the $where (page 404) operator in your query, as in the
following examples:
db.myCollection.find( { active: true, $where: "this.credits - this.debits < 0" } );
db.myCollection.find( { active: true, $where: function() { return obj.credits - obj.debits < 0; } } );
Geospatial
Geospatial Query Operators
Operators
Query Selectors
Name Description
$geoIntersects (page 406) Selects geometries that intersect with a GeoJSON geometry.
$geoWithin (page 407) Selects geometries within a bounding GeoJSON geometry.
$nearSphere (page 408) Returns geospatial objects in proximity to a point on a sphere.
$near (page 410) Returns geospatial objects in proximity to a point.
$geoIntersects
$geoIntersects
New in version 2.4.
The $geoIntersects (page 406) operator is a geospatial query operator that selects all locations that in-
tersect with a GeoJSON object. A location intersects a GeoJSON object if the intersection is non-empty. This
includes documents that have a shared edge. The $geoIntersects (page 406) operator uses spherical ge-
ometry.
The 2dsphere geospatial index supports $geoIntersects (page 406).
To query for intersection, pass the GeoJSONobject to $geoIntersects (page 406) through the $geometry
(page 414) operator. Use the following syntax:
db.<collection>.find( { <location field> :
{ $geoIntersects :
{ $geometry :
{ type : "<GeoJSON object type>" ,
coordinates : [ <coordinates> ]
} } } } )
Important: Specify coordinates in this order: longitude, latitude.
406 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The following example uses $geoIntersects (page 406) to select all indexed points and shapes that intersect
with the polygon dened by the coordinates array.
db.places.find( { loc :
{ $geoIntersects :
{ $geometry :
{ type : "Polygon" ,
coordinates: [ [ [ 0 , 0 ] , [ 3 , 6 ] , [ 6 , 1 ] , [ 0 , 0 ] ] ]
} } } } )
Note: Any geometry specied with GeoJSON to $geoIntersects (page 406) queries, must t within a
single hemisphere. MongoDB interprets geometries larger than half of the sphere as queries for the smaller of
the complementary geometries.
$geoWithin
$geoWithin
New in version 2.4: $geoWithin (page 407) replaces $within (page 408) which is deprecated.
The $geoWithin (page 407) operator is a geospatial query operator that queries for a dened point, line or
shape that exists entirely within another dened shape. When determining inclusion, MongoDB considers the
border of a shape to be part of the shape, subject to the precision of oating point numbers.
The $geoWithin (page 407) operator queries for inclusion in a GeoJSON polygon or a shape dened by
legacy coordinate pairs.
The $geoWithin (page 407) operator does not return sorted results. As a result MongoDB can re-
turn $geoWithin (page 407) queries more quickly than geospatial $near (page 410) or $nearSphere
(page 408) queries, which sort results.
The 2dsphere and 2d indexes both support the $geoWithin (page 407) operator.
Changed in version 2.2.3: $geoWithin (page 407) does not require a geospatial index. However, a geospatial
index will improve query performance.
If querying for geometries that exist within a GeoJSON polygon on a sphere, pass the polygon to $geoWithin
(page 407) using the $geometry (page 414) operator.
For a polygon with only an exterior ring use following syntax:
db.<collection>.find( { <location field> :
{ $geoWithin :
{ $geometry :
{ type : "Polygon" ,
coordinates : [ [ [ <lng1>, <lat1> ] , [ <lng2>, <lat2> ] ... ] ]
} } } } )
Important: Specify coordinates in longitude, latitude order.
For a polygon with an exterior and interior ring use following syntax:
db.<collection>.find( { <location field> :
{ $geoWithin :
{ $geometry :
{ type : "Polygon" ,
coordinates : [ [ [ <lng1>, <lat1> ] , [ <lng2>, <lat2> ] ... ]
[ [ <lngA>, <latA> ] , [ <lngB>, <latB> ] ... ] ]
} } } } )
2.3. Operators 407
MongoDB Reference Manual, Release 2.6.4
The following example selects all indexed points and shapes that exist entirely within a GeoJSON polygon:
db.places.find( { loc :
{ $geoWithin :
{ $geometry :
{ type : "Polygon" ,
coordinates: [ [ [ 0 , 0 ] , [ 3 , 6 ] , [ 6 , 1 ] , [ 0 , 0 ] ] ]
} } } } )
If querying for inclusion in a shape dened by legacy coordinate pairs on a plane, use the following syntax:
db.<collection>.find( { <location field> :
{ $geoWithin :
{ <shape operator> : <coordinates>
} } } )
For the syntax of shape operators, see: $box (page 412), $polygon (page 415), $center (page 413) (denes
a circle), and $centerSphere (page 412) (denes a circle on a sphere).
Note: Any geometry specied with GeoJSON to $geoWithin (page 407) queries, must t within a single
hemisphere. MongoDB interprets geometries larger than half of the sphere as queries for the smaller of the
complementary geometries.
$within
Deprecated since version 2.4: $geoWithin (page 407) replaces $within (page 408) in MongoDB 2.4.
$nearSphere
$nearSphere
Species a point for which a geospatial query returns the documents from nearest to farthest. MongoDB calcu-
lates distances for $nearSphere (page 408) using spherical geometry.
The $nearSphere (page 408) operator requires a geospatial index and can use either 2dsphere index or 2d
index for location data dened as GeoJSON points or legacy coordinate pairs. To use a 2d index on GeoJSON
points, create the index on the coordinates eld of the GeoJSON object.
The $nearSphere (page 408) operator can specify either a GeoJSON point or legacy coordinate point.
To specify a GeoJSON point, use the following syntax:
{
$nearSphere: {
$geometry: {
type : "Point",
coordinates : [ <longitude>, <latitude> ]
},
$minDistance: <distance in meters>,
$maxDistance: <distance in meters>
}
}
The optional $minDistance (page 414) is available only if the query uses the 2dsphere index.
$minDistance (page 414) limits the results to those documents that are at least the specied distance
from the center point.
New in version 2.6.
The optional $maxDistance (page 414) is available for either index.
To specify a point using legacy coordinates, use the following syntax:
408 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
$nearSphere: [ <x>, <y> ],
$minDistance: <distance in radians>,
$maxDistance: <distance in radians>
}
The optional $minDistance (page 414) is available only if the query uses the 2dsphere index.
$minDistance (page 414) limits the results to those documents that are at least the specied distance
from the center point.
New in version 2.6.
The optional $maxDistance (page 414) is available for either index.
If you use longitude and latitude for legacy coordinates, specify the longitude rst, then latitude.
Behavior Queries that use a 2d index return at most 100 documents.
Examples
Specify Center Point Using GeoJSON Consider a collection places that contains documents with a location
eld and has a 2dsphere index.
Then, the following example returns whose location is at least 1000 meters from and at most 5000 meters from
the specied point, ordered from nearest to farthest:
db.places.find(
{
location: {
$nearSphere: {
$geometry: {
type : "Point",
coordinates : [ -73.9667, 40.78 ]
},
$minDistance: 1000,
$maxDistance: 5000
}
}
}
)
Specify Center Point Using Legacy Coordinates
2d Index Consider a collection legacyPlaces that contains documents with legacy coordinates pairs in the
location eld and has a 2d index.
Then, the following example returns up to 100 documents whose location is at most 0.10 radians from the
specied point, ordered from nearest to farthest:
db.legacyPlaces.find(
{ location : { $nearSphere : [ -73.9667, 40.78 ], $maxDistance: 0.10 } }
)
2.3. Operators 409
MongoDB Reference Manual, Release 2.6.4
2dsphere Index If the collection has a 2dsphere index instead, you can also specify the optional
$minDistance (page 414) specication. For example, the following example returns the documents whose
location is at least 0.0004 radians from the specied point, ordered from nearest to farthest:
db.legacyPlaces.find(
{ location : { $nearSphere : [ -73.9667, 40.78 ], $minDistance: 0.0004 } }
)
$near
Denition
$near
Species a point for which a geospatial query returns the documents from nearest to farthest. The $near
(page 410) operator can specify either a GeoJSON point or legacy coordinate point.
To specify a GeoJSON point, $near (page 410) operator requires a 2dsphere index and has the following
syntax:
{
$near: {
$geometry: {
type: "Point" ,
coordinates: [ <longitude> , <latitude> ]
},
$maxDistance: <distance in meters>,
$minDistance: <distance in meters>
}
}
When specifying a GeoJSON point, you can use the optional $minDistance (page 414) and
$maxDistance (page 414) specications to limit the $near (page 410) results by distance in meters:
$minDistance (page 414) limits the results to those documents that are at least the specied distance
from the center point. $minDistance (page 414) is only available for use with 2dsphere index.
New in version 2.6.
$maxDistance (page 414) limits the results to those documents that are at most the specied distance
from the center point.
To specify a point using legacy coordinates, $near (page 410) requires a 2d index and has the following
syntax:
{
$near: [ <x>, <y> ],
$maxDistance: <distance in radians>
}
If you use longitude and latitude for legacy coordinates, specify the longitude rst, then latitude.
When specifying a legacy coordinate, you can use the optional $maxDistance (page 414) specication to
limit the $near (page 410) results by distance in radians. $maxDistance (page 414) limits the results to
those documents that are at most the specied distance from the center point.
Considerations
$near (page 410) queries that use a 2d index return a limit of 100 documents.
410 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
You cannot combine the $near (page 410) operator, which requires a special geospatial index, with a query
operator or command that uses a different type of special index. For example you cannot combine $near
(page 410) with the $text (page 401) query.
If using a 2d index for $near (page 410), specifying a batch size (i.e. batchSize() (page 80)) in con-
junction with $near (page 410) queries that use a 2d index is undened. See SERVER-5236
25
for more
information.
For sharded collections, queries using $near (page 410) are not supported. You can instead use either the
geoNear (page 227) command or the $geoNear (page 458) aggregation stage.
geoNear (page 227) always returns the documents sorted by distance. Any other sort order requires to sort the
documents in memory, which can be inefcient. To return results in a different sort order, use the $geoWithin
(page 407) operator and the sort() method.
Examples
Query on GeoJSONData
Important: Specify coordinates in this order: longitude, latitude.
Consider a collection places that has a 2dsphere index.
The following example returns documents that are at least 1000 meters from and at most 5000 meters from the
specied GeoJSON point, sorted from nearest to farthest:
db.places.find(
{
location:
{ $near :
{
$geometry: { type: "Point", coordinates: [ -73.9667, 40.78 ] },
$minDistance: 1000,
$maxDistance: 5000
}
}
}
)
Query on Legacy Coordinates
Important: Specify coordinates in this order: longitude, latitude.
Consider a collection legacy2d that has a 2d index.
The following example returns documents that are at most 0.10 radians from the specied legacy coordinate pair,
sorted from nearest to farthest:
db.legacy2d.find(
{ location : { $near : [ -73.9667, 40.78 ], $maxDistance: 0.10 } }
)
The result set contains at most 100 documents.
25
https://jira.mongodb.org/browse/SERVER-5236
2.3. Operators 411
MongoDB Reference Manual, Release 2.6.4
Geometry Speciers
Name Description
$box
(page 412)
Species a rectangular box using legacy coordinate pairs for $geoWithin (page 407)
queries.
$centerSphere
(page 412)
Species a circle using either legacy coordinate pairs or GeoJSON format for $geoWithin
(page 407) queries when using spherical geometry.
$center
(page 413)
Species a circle using legacy coordinate pairs to $geoWithin (page 407) queries when
using planar geometry.
$geometry
(page 414)
Species a geometry in GeoJSON format to geospatial query operators.
$maxDistance
(page 414)
Species a maximum distance to limit the results of $near (page 410) and $nearSphere
(page 408) queries.
$minDistance
(page 414)
Species a minimum distance to limit the results of $near (page 410) and $nearSphere
(page 408) queries. For use with 2dsphere index only.
$polygon
(page 415)
Species a polygon to using legacy coordinate pairs for $geoWithin (page 407) queries.
$uniqueDocs
(page 416)
Deprecated. Modies a $geoWithin (page 407) and $near (page 410) queries to ensure
that even if a document matches the query multiple times, the query returns the document
once.
$box
$box
New in version 1.4.
The $box (page 412) operator species a rectangle for a geospatial $geoWithin (page 407) query. The query
returns documents that are within the bounds of the rectangle, according to their point-based location data. The
$box (page 412) operator returns documents based on grid coordinates and does not query for GeoJSON
shapes.
The query calculates distances using at (planar) geometry. The 2d geospatial index supports the $box
(page 412) operator.
To use the $box (page 412) operator, you must specify the bottom left and top right corners of the rectangle in
an array object. Use the following syntax:
{ <location field> : { $geoWithin : { $box :
[ [ <bottom left coordinates> ] ,
[ <upper right coordinates> ] ] } } }
Important: If you use longitude and latitude, specify longitude rst.
The following example query returns all documents that are within the box having points at: [ 0 , 0 ], [
0 , 100 ], [ 100 , 0 ], and [ 100 , 100 ].
db.places.find( { loc : { $geoWithin : { $box :
[ [ 0 , 0 ] ,
[ 100 , 100 ] ] } } } )
Changed in version 2.2.3: Applications can use $box (page 412) without having a geospatial index. However,
geospatial indexes support much faster queries than the unindexed equivalents. Before 2.2.3, a geospatial index
must exist on a eld holding coordinates before using any of the geospatial query operators.
$centerSphere
$centerSphere
New in version 1.8.
412 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $centerSphere (page 412) operator denes a circle for a geospatial query that uses spherical geometry.
The query returns documents that are within the bounds of the circle.
You can use the $centerSphere (page 412) operator on both GeoJSON objects and legacy coordinate pairs.
The 2d and 2dsphere geospatial indexes both support $centerSphere (page 412).
To use $centerSphere (page 412), specify an array that contains:
The grid coordinates of the circles center point
The circles radius measured in radians. To calculate radians, see
http://docs.mongodb.org/manualtutorial/calculate-distances-using-spherical-geometry-with-2d-geospatial-indexes.
Use the following syntax:
db.<collection>.find( { <location field> :
{ $geoWithin :
{ $centerSphere : [ [ <x>, <y> ] , <radius> ] }
} } )
Important: If you use longitude and latitude, specify longitude rst.
The following example queries grid coordinates and returns all documents within a 10 mile radius of longitude
88 W and latitude 30 N. The query converts the distance to radians by dividing by the approximate radius of
the earth, 3959 miles:
db.places.find( { loc : { $geoWithin :
{ $centerSphere :
[ [ -88 , 30 ] , 10 / 3959 ]
} } } )
Changed in version 2.2.3: Applications can use $centerSphere (page 412) without having a geospatial
index. However, geospatial indexes support much faster queries than the unindexed equivalents. Before 2.2.3, a
geospatial index must exist on a eld holding coordinates before using any of the geospatial query operators.
$center
$center
New in version 1.4.
The $center (page 413) operator species a circle for a geospatial $geoWithin (page 407) query. The
query returns legacy coordinate pairs that are within the bounds of the circle. The operator does not return
GeoJSON objects.
The query calculates distances using at (planar) geometry.
The 2d geospatial index supports the $center (page 413) operator.
To use the $center (page 413) operator, specify an array that contains:
The grid coordinates of the circles center point
The circles radius, as measured in the units used by the coordinate system
Important: If you use longitude and latitude, specify longitude rst.
Use the following syntax:
{ <location field> : { $geoWithin : { $center : [ [ <x>, <y> ] , <radius> ] } } }
2.3. Operators 413
MongoDB Reference Manual, Release 2.6.4
The following example query returns all documents that have coordinates that exist within the circle centered
on [ -74 , 40.74 ] and with a radius of 10:
db.places.find( { loc: { $geoWithin :
{ $center : [ [-74, 40.74], 10 ] }
} } )
Changed in version 2.2.3: Applications can use $center (page 413) without having a geospatial index. How-
ever, geospatial indexes support much faster queries than the unindexed equivalents. Before 2.2.3, a geospatial
index must exist on a eld holding coordinates before using any of the geospatial query operators.
$geometry
$geometry
New in version 2.4.
The $geometry (page 414) operator species a GeoJSON for a geospatial query operators. For details on
using $geometry (page 414) with an operator, see the operator:
$geoWithin (page 407)
$geoIntersects (page 406)
$near (page 410)
$maxDistance
$maxDistance
The $maxDistance (page 414) operator constrains the results of a geospatial $near (page 410) or
$nearSphere (page 408) query to the specied distance. The measuring units for the maximum distance
are determined by the coordinate system in use. For GeoJSON point object, specify the distance in meters, not
radians.
Changed in version 2.6: Specify a non-negative number for $maxDistance (page 414).
The 2d and 2dsphere geospatial indexes both support $maxDistance (page 414).
The following example query returns documents with location values that are 10 or fewer units from the point
[ 100 , 100 ].
db.places.find( { loc : { $near : [ 100 , 100 ] ,
$maxDistance: 10 }
} )
MongoDB orders the results by their distance from [ 100 , 100 ]. The operation returns the rst 100
results, unless you modify the query with the cursor.limit() (page 89) method.
$minDistance
$minDistance
New in version 2.6.
Filters the results of a geospatial $near (page 410) or $nearSphere (page 408) query to those documents
that are at least the specied distance from the center point.
$minDistance (page 414) is available for use with 2dsphere index only.
If $near (page 410) or $nearSphere (page 408) query species the center point as a GeoJSONpoint, specify
the distance as a non-negative number in meters.
414 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
If $nearSphere (page 408) query species the center point as legacy coordinate pair, specify the distance as
a non-negative number in radians. $near (page 410) can only use the 2dsphere index if the query species
the center point as a GeoJSON point.
Examples
Use with $near
Important: Specify coordinates in this order: longitude, latitude.
Consider a collection places that has a 2dsphere index.
The following example returns documents that are at least 1000 meters from and at most 5000 meters from the
specied GeoJSON point, sorted from nearest to farthest:
db.places.find(
{
location:
{ $near :
{
$geometry: { type: "Point", coordinates: [ -73.9667, 40.78 ] },
$minDistance: 1000,
$maxDistance: 5000
}
}
}
)
Use with $nearSphere Consider a collection places that contains documents with a location eld and has
a 2dsphere index.
Then, the following example returns whose location is at least 1000 meters from and at most 5000 meters from
the specied point, ordered from nearest to farthest:
db.places.find(
{
location: {
$nearSphere: {
$geometry: {
type : "Point",
coordinates : [ -73.9667, 40.78 ]
},
$minDistance: 1000,
$maxDistance: 5000
}
}
}
)
For an example that species the center point as legacy coordinate pair, see $nearSphere (page 408)
$polygon
$polygon
New in version 1.9.
2.3. Operators 415
MongoDB Reference Manual, Release 2.6.4
The $polygon (page 415) operator species a polygon for a geospatial $geoWithin (page 407) query on
legacy coordinate pairs. The query returns pairs that are within the bounds of the polygon. The operator does
not query for GeoJSON objects.
The $polygon (page 415) operator calculates distances using at (planar) geometry.
The 2d geospatial index supports the $polygon (page 415) operator.
To dene the polygon, specify an array of coordinate points. Use the following syntax:
{ <location field> : { $geoWithin : { $polygon : [ [ <x1> , <y1> ] ,
[ <x2> , <y2> ] ,
[ <x3> , <y3> ] ] } } }
Important: If you use longitude and latitude, specify longitude rst.
The last point specied is always implicitly connected to the rst. You can specify as many points, and therefore
sides, as you like.
The following query returns all documents that have coordinates that exist within the polygon dened by [ 0
, 0 ], [ 3 , 6 ], and [ 6 , 0 ]:
db.places.find( { loc : { $geoWithin : { $polygon : [ [ 0 , 0 ] ,
[ 3 , 6 ] ,
[ 6 , 0 ] ] } } } )
Changed in version 2.2.3: Applications can use $polygon (page 415) without having a geospatial index. How-
ever, geospatial indexes support much faster queries than the unindexed equivalents. Before 2.2.3, a geospatial
index must exist on a eld holding coordinates before using any of the geospatial query operators.
$uniqueDocs
Denition
$uniqueDocs
Deprecated since version 2.6: Geospatial queries no longer return duplicate results. The $uniqueDocs
(page 416) operator has no impact on results.
Returns a document only once for a geospatial query even if the document matches the query multiple times.
Geospatial Query Compatibility While numerous combinations of query operators are possible, the following
table shows the recommended operators for different types of queries. The table uses the $geoWithin (page 407),
$geoIntersects (page 406) and $near (page 410) operators.
416 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Query Document Geometry of the
Query Condition
Surface Type for
Query Calculation
Units for Query Cal-
culation
Supported by this
Index
Returns points, lines
and polygons
{ $geoWithin : {
$geometry : <GeoJSON Polygon>
} }
polygon sphere meters 2dsphere
{ $geoIntersects : {
$geometry : <GeoJSON>
} }
point, line or polygon sphere meters 2dsphere
{ $near : {
$geometry : <GeoJSON Point>,
$maxDistance : d
} }
point sphere meters 2dsphere
The index is required.
Returns points only
{ $geoWithin : {
$box : [[x1, y1], [x2, y2]]
} }
rectangle at at units 2d
{ $geoWithin : {
$polygon : [[x1, y1],
[x1, y2],
[x2, y2],
[x2, y1]]
} }
polygon at at units 2d
{ $geoWithin : {
$center : [[x1, y1], r],
} }
circular region at at units 2d
{ $geoWithin : {
$centerSphere :
[[x, y], radius]
} }
circular region sphere radians 2d
2dsphere
{ $near : [x1, y1],
$maxDistance : d
}
point at / at units at units 2d
The index is required.
Array
2.3. Operators 417
MongoDB Reference Manual, Release 2.6.4
Query Operator Array
Name Description
$all (page 418) Matches arrays that contain all elements specied in the query.
$elemMatch
(page 421)
Selects documents if element in the array eld matches all the specied $elemMatch
(page 421) condition.
$size (page 422) Selects documents if the array eld is a specied size.
$all
$all
The $all (page 418) operator selects the documents where the value of a eld is an array that contains all the
specied elements. To specify an $all (page 418) expression, use the following prototype:
{ <field>: { $all: [ <value1> , <value2> ... ] } }
Behavior
Equivalent to $and Operation Changed in version 2.6.
The $all (page 418) is equivalent to an $and (page 390) operation of the specied values; i.e. the following
statement:
{ tags: { $all: [ "ssl" , "security" ] } }
is equivalent to:
{ $and: [ { tags: "ssl" }, { tags: "security" } ] }
Nested Array Changed in version 2.6.
When passed an array of a nested array (e.g. [ [ "A" ] ] ), $all (page 418) can now match documents where
the eld contains the nested array as an element (e.g. field: [ [ "A" ], ... ]), or the eld equals the
nested array (e.g. field: [ "A" ]).
For example, consider the following query
26
:
db.articles.find( { tags: { $all: [ [ "ssl", "security" ] ] } } )
The query is equivalent to:
db.articles.find( { $and: [ { tags: [ "ssl", "security" ] } ] } )
which is equivalent to:
db.articles.find( { tags: [ "ssl", "security" ] } )
As such, the $all (page 418) expression can match documents where the tags eld is an array that contains the
nested array [ "ssl", "security" ] or is an array that equals the nested array:
tags: [ [ "ssl", "security" ], ... ]
tags: [ "ssl", "security" ]
This behavior for $all (page 418) allows for more matches than previous versions of MongoDB. Earlier version
could only match documents where the eld contains the nested array.
26
The $all (page 418) expression with a single element is for illustrative purposes since the $all (page 418) expression is unnecessary if
matching only a single element. Instead, when matching a single element, a contains expression (i.e. arrayField: element ) is more
suitable.
418 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Performance Queries that use the $all (page 418) operator must scan all the documents that match the rst element
in the $all (page 418) expression. As a result, even with an index to support the query, the operation may be long
running, particularly when the rst element in the $all (page 418) expression is not very selective.
Examples The following examples use the inventory collection that contains the documents:
{
_id: ObjectId("5234cc89687ea597eabee675"),
code: "xyz",
tags: [ "school", "book", "bag", "headphone", "appliance" ],
qty: [
{ size: "S", num: 10, color: "blue" },
{ size: "M", num: 45, color: "blue" },
{ size: "L", num: 100, color: "green" }
]
}
{
_id: ObjectId("5234cc8a687ea597eabee676"),
code: "abc",
tags: [ "appliance", "school", "book" ],
qty: [
{ size: "6", num: 100, color: "green" },
{ size: "6", num: 50, color: "blue" },
{ size: "8", num: 100, color: "brown" }
]
}
{
_id: ObjectId("5234ccb7687ea597eabee677"),
code: "efg",
tags: [ "school", "book" ],
qty: [
{ size: "S", num: 10, color: "blue" },
{ size: "M", num: 100, color: "blue" },
{ size: "L", num: 100, color: "green" }
]
}
{
_id: ObjectId("52350353b2eff1353b349de9"),
code: "ijk",
tags: [ "electronics", "school" ],
qty: [
{ size: "M", num: 100, color: "green" }
]
}
Use $all to Match Values The following operation uses the $all (page 418) operator to query the inventory
collection for documents where the value of the tags eld is an array whose elements include appliance, school,
and book:
db.inventory.find( { tags: { $all: [ "appliance", "school", "book" ] } } )
The above query returns the following documents:
2.3. Operators 419
MongoDB Reference Manual, Release 2.6.4
{
_id: ObjectId("5234cc89687ea597eabee675"),
code: "xyz",
tags: [ "school", "book", "bag", "headphone", "appliance" ],
qty: [
{ size: "S", num: 10, color: "blue" },
{ size: "M", num: 45, color: "blue" },
{ size: "L", num: 100, color: "green" }
]
}
{
_id: ObjectId("5234cc8a687ea597eabee676"),
code: "abc",
tags: [ "appliance", "school", "book" ],
qty: [
{ size: "6", num: 100, color: "green" },
{ size: "6", num: 50, color: "blue" },
{ size: "8", num: 100, color: "brown" }
]
}
Use $all with $elemMatch If the eld contains an array of documents, you can use the $all (page 418) with
the $elemMatch (page 421) operator.
The following operation queries the inventory collection for documents where the value of the qty eld is an
array whose elements match the $elemMatch (page 421) criteria:
db.inventory.find( {
qty: { $all: [
{ "$elemMatch" : { size: "M", num: { $gt: 50} } },
{ "$elemMatch" : { num : 100, color: "green" } }
] }
} )
The query returns the following documents:
{
"_id" : ObjectId("5234ccb7687ea597eabee677"),
"code" : "efg",
"tags" : [ "school", "book"],
"qty" : [
{ "size" : "S", "num" : 10, "color" : "blue" },
{ "size" : "M", "num" : 100, "color" : "blue" },
{ "size" : "L", "num" : 100, "color" : "green" }
]
}
{
"_id" : ObjectId("52350353b2eff1353b349de9"),
"code" : "ijk",
"tags" : [ "electronics", "school" ],
"qty" : [
{ "size" : "M", "num" : 100, "color" : "green" }
]
}
The $all (page 418) operator exists to support queries on arrays. But you may use the $all (page 418) operator to
420 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
select against a non-array field, as in the following example:
db.inventory.find( { qty: { $all: [ 50 ] } } )
However, use the following form to express the same query:
db.inventory.find( { qty: 50 } )
Both queries will select all documents in the inventory collection where the value of the qty eld equals 50.
Note: In most cases, MongoDB does not treat arrays as sets. This operator provides a notable exception to this
approach.
See also:
find() (page 33), update() (page 70), and $set (page 436).
$elemMatch (query) See also:
$elemMatch (projection) (page 425)
Denition
$elemMatch
The $elemMatch (page 421) operator matches documents in a collection that contain an array eld with at
least one element that matches all the specied query criteria.
{ <field>: { $elemMatch: { <query1>, <query2>, ... } } }
Behavior You cannot specify a $where (page 404) expression as a query criterion for $elemMatch (page 421).
Examples
Element Match Given the following documents in the scores collection:
{ _id: 1, results: [ 82, 85, 88 ] }
{ _id: 2, results: [ 75, 88, 89 ] }
The following query matches only those documents where the results array contains at least one element that is
both greater than or equal to 80 and is less than 85.
db.scores.find(
{ results: { $elemMatch: { $gte: 80, $lt: 85 } } }
)
The query returns the following document since the element 82 is both greater than or equal to 80 and is less than 85
{ "_id" : 1, "results" : [ 82, 85, 88 ] }
For more information on specifying multiple criterion on array elements, see specify-multiple-criteria-for-array-
elements.
Array of Embedded Documents Given the following documents in the survey collection:
2.3. Operators 421
MongoDB Reference Manual, Release 2.6.4
{ _id: 1, results: [ { product: "abc", score: 10 }, { product: "xyz", score: 5 } ] }
{ _id: 2, results: [ { product: "abc", score: 8 }, { product: "xyz", score: 7 } ] }
{ _id: 3, results: [ { product: "abc", score: 7 }, { product: "xyz", score: 8 } ] }
The following query matches only those documents where the results array contains at least one element with both
product equal to "xyz" and score greater than or equal to 8.
db.survey.find(
{ results: { $elemMatch: { product: "xyz", score: { $gte: 8 } } } }
)
Specically, the query matches the following document:
{ "_id" : 3, "results" : [ { "product" : "abc", "score" : 7 }, { "product" : "xyz", "score" : 8 } ] }
For more information on querying arrays, see read-operations-arrays, including specify-multiple-criteria-for-array-
elements and array-match-embedded-documents sections.
$size
$size
The $size (page 422) operator matches any array with the number of elements specied by the argument. For
example:
db.collection.find( { field: { $size: 2 } } );
returns all documents in collection where field is an array with 2 elements. For instance, the above
expression will return { field: [ red, green ] } and { field: [ apple, lime ] } but
not { field: fruit } or { field: [ orange, lemon, grapefruit ] }. To match elds
with only one element within an array use $size (page 422) with a value of 1, as follows:
db.collection.find( { field: { $size: 1 } } );
$size (page 422) does not accept ranges of values. To select documents based on elds with different numbers
of elements, create a counter eld that you increment when you add elements to a eld.
Queries cannot use indexes for the $size (page 422) portion of a query, although the other portions of a query
can use indexes if applicable.
Projection Operators
Projection Operators
Name Description
$ (page 422) Projects the rst element in an array that matches the query condition.
$elemMatch
(page 425)
Projects the rst element in an array that matches the specied $elemMatch
(page 425) condition.
$meta (page 427) Projects the documents score assigned during $text (page 401) operation.
$slice (page 428) Limits the number of elements projected from an array. Supports skip and limit slices.
$ (projection)
Denition
422 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
$
The positional $ (page 422) operator limits the contents of an <array> from the query results to contain only
the rst element matching the query document. To specify an array element to update, see the positional $
operator for updates (page 437).
Use $ (page 422) in the projection document of the find() (page 33) method or the findOne() (page 42)
method when you only need one particular array element in selected documents.
Usage Considerations Both the $ (page 422) operator and the $elemMatch (page 425) operator project a subset
of elements from an array based on a condition.
The $ (page 422) operator projects the array elements based on some condition from the query statement.
The $elemMatch (page 425) projection operator takes an explicit condition argument. This allows you to project
based on a condition not in the query, or if you need to project based on multiple elds in the arrays subdocuments.
See Array Field Limitations (page 423) for an example.
Behavior
Usage Requirements Given the form:
db.collection.find( { <array>: <value> ... },
{ "<array>.$": 1 } )
db.collection.find( { <array.field>: <value> ...},
{ "<array>.$": 1 } )
The <array> eld being limited must appear in the query document, and the <value> can be documents that
contain query operator expressions (page 386).
Array Field Limitations MongoDB requires the following when dealing with projection over arrays:
Only one positional $ (page 422) operator may appear in the projection document.
Only one array eld may appear in the query document.
The query document should only contain a single condition on the array eld being projected. Multiple condi-
tions may override each other internally and lead to undened behavior.
Under these requirements, the following query is incorrect:
db.collection.find( { <array>: <value>, <someOtherArray>: <value2> },
{ "<array>.$": 1 } )
To specify criteria on multiple elds of documents inside that array, use the $elemMatch (page 421) query operator.
The following query will return any subdocuments inside a grades array that have a mean of greater than 70 and a
grade of greater than 90.
db.students.find( { grades: { $elemMatch: {
mean: { $gt: 70 },
grade: { $gt:90 }
} } },
{ "grades.$": 1 } )
You must use the $elemMatch (page 425) operator if you need separate conditions for selecting documents and for
choosing elds within those documents.
2.3. Operators 423
MongoDB Reference Manual, Release 2.6.4
Sorts and the Positional Operator When the find() (page 33) method includes a sort() (page 96), the
find() (page 33) method applies the sort() (page 96) to order the matching documents before it applies the
positional $ (page 422) projection operator.
If an array eld contains multiple documents with the same eld name and the find() (page 33) method includes a
sort() (page 96) on that repeating eld, the returned documents may not reect the sort order because the sort was
applied to the elements of the array before the $ (page 422) projection operator.
Examples
Project Array Values A collection students contains the following documents:
{ "_id" : 1, "semester" : 1, "grades" : [ 70, 87, 90 ] }
{ "_id" : 2, "semester" : 1, "grades" : [ 90, 88, 92 ] }
{ "_id" : 3, "semester" : 1, "grades" : [ 85, 100, 90 ] }
{ "_id" : 4, "semester" : 2, "grades" : [ 79, 85, 80 ] }
{ "_id" : 5, "semester" : 2, "grades" : [ 88, 88, 92 ] }
{ "_id" : 6, "semester" : 2, "grades" : [ 95, 90, 96 ] }
In the following query, the projection { "grades.$": 1 } returns only the rst element greater than or equal to
85 for the grades eld.
db.students.find( { semester: 1, grades: { $gte: 85 } },
{ "grades.$": 1 } )
The operation returns the following documents:
{ "_id" : 1, "grades" : [ 87 ] }
{ "_id" : 2, "grades" : [ 90 ] }
{ "_id" : 3, "grades" : [ 85 ] }
Although the array eld grades may contain multiple elements that are greater than or equal to 85, the $ (page 422)
projection operator returns only the rst matching element from the array.
Project Array Documents A students collection contains the following documents where the grades eld is
an array of documents; each document contain the three eld names grade, mean, and std:
{ "_id" : 7, semester: 3, "grades" : [ { grade: 80, mean: 75, std: 8 },
{ grade: 85, mean: 90, std: 5 },
{ grade: 90, mean: 85, std: 3 } ] }
{ "_id" : 8, semester: 3, "grades" : [ { grade: 92, mean: 88, std: 8 },
{ grade: 78, mean: 90, std: 5 },
{ grade: 88, mean: 85, std: 3 } ] }
In the following query, the projection { "grades.$": 1 } returns only the rst element with the mean greater
than 70 for the grades eld:
db.students.find(
{ "grades.mean": { $gt: 70 } },
{ "grades.$": 1 }
)
The operation returns the following documents:
{ "_id" : 7, "grades" : [ { "grade" : 80, "mean" : 75, "std" : 8 } ] }
{ "_id" : 8, "grades" : [ { "grade" : 92, "mean" : 88, "std" : 8 } ] }
424 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Further Reading $elemMatch (projection) (page 425)
$elemMatch (projection) See also:
$elemMatch (query) (page 421)
Denition
$elemMatch
New in version 2.2.
The $elemMatch (page 425) operator limits the contents of an <array> eld from the query results to
contain only the rst element matching the $elemMatch (page 425) condition.
Usage Considerations Both the $ (page 422) operator and the $elemMatch (page 425) operator project a subset
of elements from an array based on a condition.
The $ (page 422) operator projects the array elements based on some condition from the query statement.
The $elemMatch (page 425) projection operator takes an explicit condition argument. This allows you to project
based on a condition not in the query, or if you need to project based on multiple elds in the arrays subdocuments.
See Array Field Limitations (page 423) for an example.
Examples The examples on the $elemMatch (page 425) projection operator assumes a collection school with
the following documents:
{
_id: 1,
zipcode: "63109",
students: [
{ name: "john", school: 102, age: 10 },
{ name: "jess", school: 102, age: 11 },
{ name: "jeff", school: 108, age: 15 }
]
}
{
_id: 2,
zipcode: "63110",
students: [
{ name: "ajax", school: 100, age: 7 },
{ name: "achilles", school: 100, age: 8 },
]
}
{
_id: 3,
zipcode: "63109",
students: [
{ name: "ajax", school: 100, age: 7 },
{ name: "achilles", school: 100, age: 8 },
]
}
{
_id: 4,
zipcode: "63109",
students: [
{ name: "barney", school: 102, age: 7 },
{ name: "ruth", school: 102, age: 16 },
2.3. Operators 425
MongoDB Reference Manual, Release 2.6.4
]
}
Zipcode Search The following find() (page 33) operation queries for all documents where the value of the
zipcode eld is 63109. The $elemMatch (page 425) projection returns only the rst matching element of
the students array where the school eld has a value of 102:
db.schools.find( { zipcode: "63109" },
{ students: { $elemMatch: { school: 102 } } } )
The operation returns the following documents:
{ "_id" : 1, "students" : [ { "name" : "john", "school" : 102, "age" : 10 } ] }
{ "_id" : 3 }
{ "_id" : 4, "students" : [ { "name" : "barney", "school" : 102, "age" : 7 } ] }
For the document with _id equal to 1, the students array contains multiple elements with the school eld
equal to 102. However, the $elemMatch (page 425) projection returns only the rst matching element from
the array.
The document with _id equal to 3 does not contain the students eld in the result since no element in its
students array matched the $elemMatch (page 425) condition.
$elemMatch with Multiple Fields The $elemMatch (page 425) projection can specify criteria on multiple
elds:
The following find() (page 33) operation queries for all documents where the value of the zipcode eld is 63109.
The projection includes the rst matching element of the students array where the school eld has a value of
102 and the age eld is greater than 10:
db.schools.find( { zipcode: "63109" },
{ students: { $elemMatch: { school: 102, age: { $gt: 10} } } } )
The operation returns the three documents that have zipcode equal to 63109:
{ "_id" : 1, "students" : [ { "name" : "jess", "school" : 102, "age" : 11 } ] }
{ "_id" : 3 }
{ "_id" : 4, "students" : [ { "name" : "ruth", "school" : 102, "age" : 16 } ] }
Documents with _id equal to 3 and _id equal to 4 do not contain the students eld since no array element
matched the $elemMatch (page 425) criteria.
$elemMatch with sort() When the find() (page 33) method includes a sort() (page 96), the find()
(page 33) method applies the sort() (page 96) to order the matching documents before it applies the projection.
This is a general rule when sorting and projecting, and is discussed in Interaction with Projection (page 98).
If an array eld contains multiple documents with the same eld name and the find() (page 33) method includes a
sort() (page 96) on that repeating eld, the returned documents may not reect the sort order because the sort()
(page 96) was applied to the elements of the array before the $elemMatch (page 425) projection.
An arrays sorting value is taken from either its minimum or maximum value, depending on which way the sorting
goes. The way that sort() (page 96) sorts documents containing arrays is described in Ascending/Descending Sort
(page 97).
The following query includes a sort() (page 96) to order by descending students.age eld:
426 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.schools.find(
{ zipcode: "63109" },
{ students: { $elemMatch: { school: 102 } } }
).sort( { "students.age": -1 } )
The operation applies the sort() (page 96) to order the documents that have the eld zipcode equal to 63109
and then applies the projection. The operation returns the three documents in the following order:
{ "_id" : 4, "students" : [ { "name" : "barney", "school" : 102, "age" : 7 } ] }
{ "_id" : 1, "students" : [ { "name" : "john", "school" : 102, "age" : 10 } ] }
{ "_id" : 3 }
Even though the sort is descending, the younger student is listed rst. This is because the sort occured before the older
students in Barneys document were projected out.
See also:
$ (projection) (page 422) operator
$meta
$meta
New in version 2.6.
The $meta (page 427) projection operator returns for each matching document the metadata (e.g.
"textScore") associated with the query.
A $meta (page 427) expression has the following syntax:
{ $meta: <metaDataKeyword> }
The $meta (page 427) expression can specify the following keyword as the <metaDataKeyword>:
Key-
word
Description Sort
Or-
der
"textScore" Returns the score associated with the corresponding $text (page 401) query for each
matching document. The text score signies how well the document matched the
stemmed term or terms. If not used in conjunction with a $text (page 401) query,
returns a score of 0.
De-
scend-
ing
Behaviors The $meta (page 427) expression can be a part of the projection document as well as a sort()
(page 96) expression as:
{ <projectedFieldName>: { $meta: "textScore" } }
Projected Field Name The <projectedFieldName> cannot include a dot (.) in the name.
If the specied <projectedFieldName> already exists in the matching documents, in the result set, the existing
elds will return with the $meta (page 427) values instead of with the stored values.
Projection The $meta (page 427) expression can be used in the projection document, as in:
db.collection.find(
<query>,
{ score: { $meta: "textScore" } }
)
2.3. Operators 427
MongoDB Reference Manual, Release 2.6.4
The $meta (page 427) expression species the inclusion of the eld to the result set and does not specify the exclusion
of the other elds.
The $meta (page 427) expression can be a part of a projection document that species exclusions of other elds or
that species inclusions of other elds.
The metadata returns information on the processing of the <query> operation. As such, the returned metadata, as-
signed to the <projectedFieldName>, has no meaning inside a <query> expression; i.e. specifying a condition
on the <projectedFieldName> as part of the <query> is similar to specifying a condition on a non-existing
eld if no eld exists in the documents with the <projectedFieldName>.
Sort The $meta (page 427) expression can be part of a sort() (page 96) expression, as in:
db.collection.find(
<query>,
{ score: { $meta: "textScore" } }
).sort( { score: { $meta: "textScore" } } )
To include a $meta (page 427) expression in a sort() (page 96) expression, the same $meta (page 427) expres-
sion, including the <projectedFieldName>, must appear in the projection document. The specied metadata
determines the sort order. For example, the "textScore" metadata sorts in descending order.
For additional examples, see Text Search with Additional Query and Sort Expressions (page 404).
Examples For examples of "textScore" projections and sorts, see $text (page 401).
$slice (projection)
$slice
The $slice (page 428) operator controls the number of items of an array that a query returns. For information
on limiting the size of an array during an update with $push (page 444), see the $slice (page 449) modier
instead.
Consider the following prototype query:
db.collection.find( { field: value }, { array: {$slice: count } } );
This operation selects the document collection identied by a eld named field that holds value and
returns the number of elements specied by the value of count from the array stored in the array eld. If
count has a value greater than the number of elements in array the query returns all elements of the array.
$slice (page 428) accepts arguments in a number of formats, including negative values and arrays. Consider
the following examples:
db.posts.find( {}, { comments: { $slice: 5 } } )
Here, $slice (page 428) selects the rst ve items in an array in the comments eld.
db.posts.find( {}, { comments: { $slice: -5 } } )
This operation returns the last ve items in array.
The following examples specify an array as an argument to $slice (page 428). Arrays take the form of [
skip , limit ], where the rst value indicates the number of items in the array to skip and the second
value indicates the number of items to return.
db.posts.find( {}, { comments: { $slice: [ 20, 10 ] } } )
Here, the query will only return 10 items, after skipping the rst 20 items of that array.
428 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.posts.find( {}, { comments: { $slice: [ -20, 10 ] } } )
This operation returns 10 items as well, beginning with the item that is 20th from the last item of the array.
2.3.2 Update Operators
Update Operators
Fields
Field Update Operators
Name Description
$currentDate
(page 429)
Sets the value of a eld to current date, either as a Date or a Timestamp.
$inc (page 430) Increments the value of the eld by the specied amount.
$max (page 430) Only updates the eld if the specied value is greater than the existing eld value.
$min (page 431) Only updates the eld if the specied value is less than the existing eld value.
$mul (page 432) Multiplies the value of the eld by the specied amount.
$rename
(page 434)
Renames a eld.
$setOnInsert
(page 435)
Sets the value of a eld if an update results in an insert of a document. Has no effect on
update operations that modify existing documents.
$set (page 436) Sets the value of a eld in a document.
$unset
(page 436)
Removes the specied eld from a document.
$currentDate
$currentDate
The $currentDate (page 429) operator sets the value of a eld to the current date, either as a Date or a
timestamp. The default type is date.
The $currentDate (page 429) operator can take as its operand either
a boolean true which creates a Date, or
a document which explicitly species the type, i.e. { $type: "timestamp" } or { $type:
"date" }. The operator is case-sensitive and accepts only the lowercase "timestamp" or the lower-
case "date".
Example Consider the following document in the users collection:
{ _id: 1, status: "a", lastModified: ISODate("2013-10-02T01:11:18.965Z") }
The following updates the lastModified eld to the current date and the lastModifiedTS eld to the current
timestamp as well as setting the status eld to "D".
db.users.update( { _id: 1 },
{
$currentDate: {
lastModified: true,
lastModifiedTS: { $type: "timestamp" }
},
$set: { status: "D" }
}
)
2.3. Operators 429
MongoDB Reference Manual, Release 2.6.4
Following this operation, the updated document would resemble:
{
_id: 1,
status: "D",
lastModified: ISODate("2013-10-02T01:11:53.976Z"),
lastModifiedTS: Timestamp(1380676313, 1)
}
$inc
Denition
$inc
The $inc (page 430) operator increments a eld by a specied value and has the following form:
{ $inc: { <field1>: <amount1>, <field2>: <amount2>, ... } }
Behavior The $inc (page 430) operator accepts positive and negative values.
If the eld does not exist, $inc (page 430) adds the eld to a document and sets the eld to the specied value.
Use of the $inc (page 430) operator on a eld with a null value will generate an error.
Example The following update() (page 70) operation uses the $inc (page 430) operator to decrease the
quantity eld and increase the sales eld for the rst matching document in the products collection where
sku equals abc123.
db.products.update( { sku: "abc123" },
{ $inc: { quantity: -2, sales: 2 } } )
The $inc (page 430) operator expression species -2 for the quantity eld to decrease the value of the
quantity eld (i.e. increment by -2) and species 2 for the sales eld to increase the value of the sales
eld by 2.
See the update() (page 70) method for more information.
$max
$max
The $max (page 430) operator updates the value of the eld to a specied value if the specied value is greater
than the current value of the eld. If the eld does not exists, the $max (page 430) operator sets the eld
to the specied value. The $max (page 430) operator can compare values of different types, using the BSON
comparison order.
Examples
Use $max to Compare Numbers Consider the following document in the collection scores:
{ _id: 1, highScore: 800, lowScore: 200 }
The highScore for the document currently has the value 800. The following operation uses $max (page 530) to
compare the 800 and the specied value 950 and updates the value of highScore to 950 since 950 is greater than
800:
430 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.scores.update( { _id: 1 }, { $max: { highScore: 950 } } )
The scores collection now contains the following modied document:
{ _id: 1, highScore: 950, lowScore: 200 }
The next operation has no effect since the current value of the eld highScore, i.e. 950, is greater than 870:
db.scores.update( { _id: 1 }, { $max: { highScore: 870 } } )
The document remains unchanged in the scores collection:
{ _id: 1, highScore: 950, lowScore: 200 }
Use $max to Compare Dates Consider the following document in the collection tags:
{
_id: 1,
desc: "crafts",
dateEntered: ISODate("2013-10-01T05:00:00Z"),
dateExpired: ISODate("2013-10-01T16:38:16.163Z")
}
The following operation compares the current value of the dateExpired eld, i.e.
ISODate("2013-10-01T16:38:16.163Z"), with the specied date new Date("2013-09-30") to
determine whether to update the eld:
db.tags.update( { _id: 1 },
{
$max: {
dateExpired: new Date("2013-09-30"),
}
}
)
The operation does not update the dateExpired eld:
{
_id: 1,
desc: "decorative arts",
dateEntered: ISODate("2013-10-01T05:00:00Z"),
dateExpired: ISODate("2013-10-01T16:38:16.163Z")
}
$min
$min
The $min (page 431) updates the value of the eld to a specied value if the specied value is less than the
current value of the eld. If the eld does not exists, the $min (page 431) operator sets the eld to the specied
value. The $min (page 431) operator can compare values of different types, using the BSON comparison order.
Examples
Use $min to Compare Numbers Consider the following document in the collection scores:
2.3. Operators 431
MongoDB Reference Manual, Release 2.6.4
{ _id: 1, highScore: 800, lowScore: 200 }
The lowScore for the document currently has the value 200. The following operation uses $min (page 431) to
compare 200 to the specied value 150 and updates the value of lowScore to 150 since 150 is less than 200:
db.scores.update( { _id: 1 }, { $min: { lowScore: 150 } } )
The scores collection now contains the following modied document:
{ _id: 1, highScore: 800, lowScore: 150 }
The next operation has no effect since the current value of the eld lowScore, i.e 150, is less than 200:
db.scores.update( { _id: 1 }, { $min: { lowScore: 250 } } )
The document remains unchanged in the scores collection:
{ _id: 1, highScore: 800, lowScore: 150 }
Use $min to Compare Dates Consider the following document in the collection tags:
{
_id: 1,
desc: "crafts",
dateEntered: ISODate("2013-10-01T05:00:00Z"),
dateExpired: ISODate("2013-10-01T16:38:16Z")
}
The following operation compares the current value of the dateEntered eld, i.e.
ISODate("2013-10-01T05:00:00Z"), with the specied date new Date("2013-09-25") to de-
termine whether to update the eld:
db.tags.update( { _id: 1 },
{
$min: {
dateEntered: new Date("2013-09-25")
}
}
)
The operation updates the dateEntered eld:
{
_id: 1,
desc: "crafts",
dateEntered: ISODate("2013-09-25T00:00:00Z"),
dateExpired: ISODate("2013-10-01T16:38:16Z")
}
$mul
$mul
New in version 2.6.
Multiply the value of a eld by a number. To specify a $mul (page 432) expression, use the following prototype:
{ $mul: { field: <number> } }
432 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The eld to update must contain a numeric value. If the eld does not exist in a document, $mul (page 432)
creates the eld and sets the value to zero of the same numeric type as the multiplier.
Multiplication with values of mixed numeric types (32-bit integer, 64-bit integer, oat) may result in conversion
of numeric type. See Multiplication Type Conversion Rules for details.
Examples
Multiply the Value of a Field Consider a collection products with the following document:
{ _id: 1, item: "ABC", price: 10.99 }
The following db.collection.update() (page 70) operation updates the document, using the $mul (page 432)
operator to multiply the value in the price eld by 1.25:
db.products.update(
{ _id: 1 },
{ $mul: { price: 1.25 } }
)
The operation results in the following document, where the new value of the price eld 13.7375 reects the
original value 10.99 multiplied by 1.25:
{ _id: 1, item: "ABC", price: 13.7375 }
Apply $mul Operator to a Non-existing Field Consider a collection products with the following document:
{ _id: 2, item: "Unknown" }
The following db.collection.update() (page 70) operation updates the document, applying the $mul
(page 432) operator to the eld price that does not exist in the document:
db.products.update(
{ _id: 2 },
{ $mul: { price: NumberLong(100) } }
)
The operation results in the following document with a price eld set to value 0 of numeric type shell-type-long, the
same type as the multiplier:
{ "_id" : 2, "item" : "Unknown", "price" : NumberLong(0) }
Multiply Mixed Numeric Types Consider a collection products with the following document:
{ _id: 3, item: "XYZ", price: NumberLong(10) }
The following db.collection.update() (page 70) operation uses the $mul (page 432) operator to multiply
the value in the price eld NumberLong(10) by NumberInt(5):
db.products.update(
{ _id: 3 },
{ $mul: { price: NumberInt(5) } }
)
The operation results in the following document:
2.3. Operators 433
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 3, "item" : "XYZ", "price" : NumberLong(50) }
The value in the price eld is of type shell-type-long. See Multiplication Type Conversion Rules for details.
$rename
$rename
New in version 1.7.2.
Syntax: {$rename: { <old name1>: <new name1>, <old name2>: <new name2>,
... } }
The $rename (page 434) operator updates the name of a eld. The new eld name must differ from the existing
eld name.
Consider the following example:
db.students.update( { _id: 1 }, { $rename: { 'nickname': 'alias', 'cell': 'mobile' } } )
This operation renames the eld nickname to alias, and the eld cell to mobile.
Behavior The $rename (page 434) operator logically performs an $unset (page 436) of both the old name and
the new name, and then performs a $set (page 436) operation with the new name. As such, the operation may not
preserve the order of the elds in the document; i.e. the renamed eld may move within the document.
If the document already has a eld with the new eld name, the $rename (page 434) operator removes that eld and
renames the eld with the old eld name to the new eld name.
For elds in embedded documents, the $rename (page 434) operator can rename these elds as well as move the
elds in and out of embedded documents. $rename (page 434) does not work if these elds are in array elements.
Examples A collection students the following document where a eld nmae appears misspelled, i.e. should be
name:
{ "_id": 1,
"alias": [ "The American Cincinnatus", "The American Fabius" ],
"mobile": "555-555-5555",
"nmae": { "first" : "george", "last" : "washington" }
}
The examples in this section successively updates this document.
Rename a Field To rename a eld, call the $rename (page 434) operator with the current name of the eld and the
new name:
db.students.update( { _id: 1 }, { $rename: { "nmae": "name" } } )
This operation renames the eld nmae to name:
{
"_id": 1,
"alias": [ "The American Cincinnatus", "The American Fabius" ],
"mobile": "555-555-5555",
"name": { "first" : "george", "last" : "washington" }
}
434 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Rename a Field in an Embedded Document To rename a eld in an embedded document, call the $rename
(page 434) operator using the dot notation to refer to the eld. If the eld is to remain in the same embedded document,
also use the dot notation in the new name, as in the following:
db.students.update( { _id: 1 }, { $rename: { "name.first": "name.fname" } } )
This operation renames the embedded eld first to fname:
{
"_id" : 1,
"alias" : [ "The American Cincinnatus", "The American Fabius" ],
"mobile" : "555-555-5555",
"name" : { "fname" : "george", "last" : "washington" }
}
Rename a Field That Does Not Exist When renaming a eld and the existing eld name refers to a eld that does
not exist, the $rename (page 434) operator does nothing, as in the following:
db.students.update( { _id: 1 }, { $rename: { 'wife': 'spouse' } } )
This operation does nothing because there is no eld named wife.
$setOnInsert
$setOnInsert
New in version 2.4.
If an update operation with upsert: true (page 72) results in an insert of a document, then $setOnInsert
(page 435) assigns the specied values to the elds in the document. If the update operation does not result in
an insert, $setOnInsert (page 435) is ignored.
You can specify the upsert option for either the db.collection.update() (page 70) or
db.collection.findAndModify() (page 38) methods.
db.collection.update(
<query>,
{ $setOnInsert: { <field1>: <value1>, ... } },
{ upsert: true }
)
Example A collection named products contains no documents.
Then, the following db.collection.update() (page 70) with upsert: true (page 72) inserts a new document.
db.products.update(
{ _id: 1 },
{
$set: { item: "apple" },
$setOnInsert: { defaultQty: 100 }
},
{ upsert: true }
)
The new document is created with _id equal to 1 from the <query> condition, and the $set (page 436) and
$setOnInsert (page 435) operations are applied to this document.
The products collection contains the newly-inserted document:
2.3. Operators 435
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 1, "item" : "apple", "defaultQty" : 100 }
If the db.collection.update() (page 70) with upsert: true (page 72) had found a matching document, then
MongoDB performs an update, applying the $set (page 436) operation but ignoring the $setOnInsert (page 435)
operation.
$set
$set
The $set (page 436) operator replaces the value of a eld to the specied value. If the eld does not exist, the
$set (page 436) operator will add the eld with the specied value.
The $set (page 436) operator expression has the following form:
{ $set: { <field1>: <value1>, ... } }
To access elds in embedded documents, use the dot notation.
Examples By default, db.collection.update() (page 70) method updates the rst document that matches
the update condition. Use the multi option to update all matching documents.
Update a Single Document Consider a collection products with the following document:
{ _id: 100, sku: "abc123", quantity: 250, instock: false, details: { model: "14Q2", make: "xyz" } }
The following operation uses the $set (page 436) operator to update the value of the quantity eld to 500,
instock eld to true, and make eld in the details document to "ZYX" for the rst document where the eld
sku has the value "abc123":
db.products.update(
{ sku: "abc123" },
{ $set: { quantity: 500, instock: true, "details.make": "ZYX" } }
)
Update Multiple Documents To update all matching documents in the collection, specify multi: true option
in the update() (page 70) method, as in the following example which sets the value of the eld instock to true
for all documents in the products collection where the quantity eld is greater than (i.e. $gt (page 386)) 0 :
db.products.update(
{ quantity: { $gt: 0 } },
{ $set: { instock: true } },
{ multi: true }
)
For more examples, see update() (page 70).
$unset
$unset
The $unset (page 436) operator deletes a particular eld. The specied value in the $unset (page 436)
expression (i.e. "" below) does not impact the operation. If the eld does not exist, then $unset (page 436)
has no effect. Consider the following syntax:
{ $unset: { <field1>: "", ... } }
436 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
For example, the following update() (page 70) operation uses the $unset (page 436) operator to remove
the elds quantity and instock from the rst document found in the products collection where the eld
sku has a value of unknown.
db.products.update( { sku: "unknown" },
{ $unset: {
quantity: "",
instock: ""
}
}
)
To remove the elds from all documents in the collection where the eld sku has a value of unknown, specify
the multi: true option in the update() (page 70) method, as in the following example:
db.products.update( { sku: "unknown" },
{ $unset: {
quantity: "",
instock: ""
}
},
{ multi: true }
)
Array
Array Update Operators
Update Operators
Name Description
$ (page 437) Acts as a placeholder to update the rst element that matches the query condition in an
update.
$addToSet
(page 439)
Adds elements to an array only if they do not already exist in the set.
$pop (page 440) Removes the rst or last item of an array.
$pullAll
(page 441)
Removes all matching values from an array.
$pull (page 442) Removes all array elements that match a specied query.
$pushAll
(page 444)
Deprecated. Adds several items to an array.
$push (page 444) Adds an item to an array.
$ (update)
Denition
$
Syntax: { "<array>.$" : value }
The positional $ operator identies an element in an array eld to update without explicitly specifying the
position of the element in the array. To project, or return, an array element from a read operation, see the $
(page 422) projection operator.
When used with the update() (page 70) method,
the positional $ operator acts as a placeholder for the rst element that matches the query document, and
2.3. Operators 437
MongoDB Reference Manual, Release 2.6.4
the array eld must appear as part of the query document.
db.collection.update( { <array>: value ... }, { <update operator>: { "<array>.$" : value } } )
Behavior
Upserts Do not use the positional operator $ with upsert operations because inserts will use the $ as a eld name in
the inserted document.
Nested Arrays The positional $ operator cannot be used for queries which traverse more than one array, such as
queries that traverse arrays nested within other arrays, because the replacement for the $ placeholder is a single value
Unsets When used with the $unset (page 436) operator, the positional $ operator does not remove the matching
element from the array but rather sets it to null.
Negations If the query matches the array using a negation operator, such as $ne (page 389), $not (page 392), or
$nin (page 390), then you cannot use the positional operator to update values from this array.
However, if the negated portion of the query is inside of an $elemMatch (page 421) expression, then you can use
the positional operator to update this eld.
Examples
Update Values in an Array Consider a collection students with the following documents:
{ "_id" : 1, "grades" : [ 80, 85, 90 ] }
{ "_id" : 2, "grades" : [ 88, 90, 92 ] }
{ "_id" : 3, "grades" : [ 85, 100, 90 ] }
To update 80 to 82 in the grades array in the rst document, use the positional $ operator if you do not know the
position of the element in the array:
db.students.update( { _id: 1, grades: 80 }, { $set: { "grades.$" : 82 } } )
Remember that the positional $ operator acts as a placeholder for the rst match of the update query document.
Update Documents in an Array The positional $ operator facilitates updates to arrays that contain embedded
documents. Use the positional $ operator to access the elds in the embedded documents with the dot notation on the
$ operator.
db.collection.update( { <query selector> }, { <update operator>: { "array.$.field" : value } } )
Consider the following document in the students collection whose grades element value is an array of embedded
documents:
{ "_id" : 4, "grades" : [ { grade: 80, mean: 75, std: 8 },
{ grade: 85, mean: 90, std: 5 },
{ grade: 90, mean: 85, std: 3 } ] }
Use the positional $ operator to update the value of the std eld in the embedded document with the grade of 85:
438 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.students.update( { _id: 4, "grades.grade": 85 }, { $set: { "grades.$.std" : 6 } } )
Update Embedded Documents Using Multiple Field Matches The $ operator can update the rst array element
that matches multiple query criteria specied with the $elemMatch() (page 421) operator.
Consider the following document in the students collection whose grades eld value is an array of embedded
documents:
{ "_id" : 4, "grades" : [ { grade: 80, mean: 75, std: 8 },
{ grade: 85, mean: 90, std: 5 },
{ grade: 90, mean: 85, std: 3 } ] }
In the example below, the $ operator updates the value of the std eld in the rst embedded document that has
grade eld with a value less than or equal to 90 and a mean eld with a value greater than 80:
db.students.update(
{ _id: 4, grades: { $elemMatch: { "grade" : { $lte: 90 }, "mean" : { $gt: 80 } } } },
{ $set: { "grades.$.std" : 6 } }
)
This operation updates the rst embedded document that matches the criteria, namely the second embedded document
in the array:
{ "_id" : 4, "grades" : [ { grade: 80, mean: 75, std: 8 },
{ grade: 85, mean: 90, std: 6 },
{ grade: 90, mean: 85, std: 3 } ] }
Further Reading update() (page 70), $elemMatch() (page 421), $set (page 436) and $unset (page 436)
$addToSet
Denition
$addToSet
The $addToSet (page 439) operator adds a value to an array only if the value is not already in the array. If
the value is in the array, $addToSet (page 439) does not modify the array.
db.collection.update( <query>, { $addToSet: { <field>: <value> } } );
For example, if a collection inventory has the following document:
{ _id: 1, item: "filter", tags: [ "electronics", "camera" ] }
The following operation adds the element "accessories" to the tags array since "accessories" does
not exist in the array:
db.inventory.update(
{ _id: 1 },
{ $addToSet: { tags: "accessories" } }
)
However, the following operation has no effect as "camera" is already an element of the tags array:
db.inventory.update(
{ _id: 1 },
{ $addToSet: { tags: "camera" } }
)
2.3. Operators 439
MongoDB Reference Manual, Release 2.6.4
Behavior
$addToSet (page 439) only ensures that there are no duplicate items added to the set and does not affect
existing duplicate elements. $addToSet (page 439) does not guarantee a particular ordering of elements in
the modied set.
If the eld is absent in the document to update, $addToSet (page 439) adds the array eld with the value as
its element.
If the eld is not an array, the operation will fail.
If the value is an array, $addToSet (page 439) appends the whole array as a single element. To add each
element of the value separately, use $addToSet (page 439) with the $each (page 446) modier. See Modiers
(page 440) for details.
If the value is a document, MongoDB determines that the document is a duplicate if an existing document in the
array matches the to-be-added document exactly; i.e. the existing document has the exact same eld and values
and the elds are in the same order.
As such, eld order matters and you cannot specify that MongoDB compare only a subset of the elds in the
document to determine whether the document is a duplicate of an existing array element.
Modiers You can use the $addToSet (page 439) operator with the $each (page 446) modier. The $each
(page 446) modier allows to $addToSet (page 439) operator to add multiple values to the array eld.
A collection inventory has the following document:
{ _id: 2, item: "cable", tags: [ "electronics", "supplies" ] }
Then the following operation uses the $addToSet (page 439) operator with the $each (page 446) modier to add
multiple elements to the tags array:
db.inventory.update(
{ _id: 2 },
{ $addToSet: { tags: { $each: [ "camera",
"electronics",
"accessories" ] } } }
)
The operation adds only "camera" and "accessories" to the tags array since "electronics" already
exists in the array:
{ _id: 2,
item: "cable",
tags: [ "electronics", "supplies", "camera", "accessories" ] }
See also:
$push (page 444)
$pop
$pop
New in version 1.1.
The $pop (page 440) operator removes the rst or last element of an array. Pass $pop (page 440) a value of
-1 to remove the rst element of an array and 1 to remove the last element in an array.
db.collection.update( <query>,
{ $pop: { <field>: <-1 | 1> } }
)
440 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Behavior The $pop (page 440) operation fails if the <field> is not an array.
If the $pop (page 440) operator removes the last item in the <field>, the <field> will then hold an empty array.
Examples
Remove the First Item of an Array Given the following document in a collection students:
{ _id: 1, scores: [ 8, 9, 10 ] }
The following example removes the rst element (8) in the scores array:
db.students.update( { _id: 1 }, { $pop: { scores: -1 } } )
After the operation, the updated document has the rst item 8 removed from its scores array:
{ _id: 1, scores: [ 9, 10 ] }
Remove the Last Item of an Array Given the following document in a collection students:
{ _id: 1, scores: [ 9, 10 ] }
The following example removes the last element (10) in the scores array by specifying 1 in the $pop (page 440)
expression:
db.students.update( { _id: 1 }, { $pop: { scores: 1 } } )
After the operation, the updated document has the last item 10 removed from its scores array:
{ _id: 1, scores: [ 9 ] }
$pullAll
$pullAll
The $pullAll (page 441) operator removes all instances of the specied values from an existing array.
db.collection.update( <query>,
{ $pullAll: { <arrayField>: [ <value1>, <value2> ... ] } }
)
Unlike the $pull (page 442) operator that removes elements by specifying a query, $pullAll (page 441)
removes elements that match the listed values.
For example, given the following document in the survey collection:
{ _id: 1, scores: [ 0, 2, 5, 5, 1, 0 ] }
The following operation removes all instances of the value 0 and 5 from the scores array:
db.survey.update( { _id: 1 }, { $pullAll: { scores: [ 0, 5 ] } } )
After the operation, the updated document has all instances of 0 and 5 removed from the scores eld:
{ "_id" : 1, "scores" : [ 2, 1 ] }
2.3. Operators 441
MongoDB Reference Manual, Release 2.6.4
$pull
$pull
The $pull (page 442) operator removes from an existing array all instances of a value or values that match a
specied query.
{ $pull: { <arrayField>: <value|query> } }
If the array elements are embedded documents, $pull (page 442) operator applies its specied query to each
element as though it were a top-level object. See Remove Items from an Array of Documents (page 442) for an
example.
Examples
Remove All Items That Equals a Specied Value Given the following documents in the cpuinfo collection:
{ _id: 1, flags: [ "vme", "de", "msr", "tsc", "pse", "msr" ] }
{ _id: 2, flags: [ "msr", "pse", "tsc" ] }
The following operation removes the value "msr" from the flags array:
db.cpuinfo.update(
{ flags: "msr" },
{ $pull: { flags: "msr" } },
{ multi: true }
)
After the operation, the documents no longer contain any "msr" values in the flags array:
{ _id: 1, flags: [ "vme", "de", "tsc", "pse" ] }
{ _id: 2, flags: [ "pse", "tsc" ] }
Remove All Items That Match a Specied $pull Condition Given the following document in the profiles
collection:
{ _id: 1, votes: [ 3, 5, 6, 7, 7, 8 ] }
The following operation will remove all items from the votes array that are greater than or equal to ($gte
(page 387)) 6:
db.profiles.update( { _id: 1 }, { $pull: { votes: { $gte: 6 } } } )
After the update operation, the document only has values less than 6:
{ _id: 1, votes: [ 3, 5 ] }
Remove Items from an Array of Documents A survey collection contains the following documents:
{
_id: 1,
results: [
{ item: "A", score: 5 },
{ item: "B", score: 8, comment: "Strongly agree" }
]
}
{
_id: 2,
442 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
results: [
{ item: "C", score: 8, comment: "Strongly agree" },
{ item: "B", score: 4 }
]
}
The following operation will remove from the results array all elements that contain a score eld equal to 8 and
item eld equal to "B":
db.survey.update(
{ },
{ $pull: { results: { score: 8 , item: "B" } } },
{ multi: true }
)
The $pull (page 442) expression applies the condition to each element of the results array as though it were a
top-level document.
After the operation, the results array contains no documents that contains score eld equal to 8 and item eld
equal to "B".
{
"_id" : 1,
"results" : [ { "item" : "A", "score" : 5 } ]
}
{
"_id" : 2,
"results" : [
{ "item" : "C", "score" : 8, "comment" : "Strongly agree" },
{ "item" : "B", "score" : 4 }
]
}
Because $pull (page 442) operator applies its query to each element as though it were a top-level object, the expres-
sion did not require the use of $elemMatch (page 421) to specify the condition of a score eld equal to 8 and
item eld equal to "B". In fact, the following operation will not pull any element from the original collection.
db.survey.update(
{ },
{ $pull: { results: { $elemMatch: { score: 8 , item: "B" } } } },
{ multi: true }
)
However, if the survey collection contained the following documents, where the results array contains embedded
documents that also contain arrays:
{
_id: 1,
results: [
{ item: "A", score: 5, answers: [ { q: 1, a: 4 }, { q: 2, a: 6 } ] },
{ item: "B", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 9 } ] }
]
}
{
_id: 2,
results: [
{ item: "C", score: 8, answers: [ { q: 1, a: 8 }, { q: 2, a: 7 } ] },
{ item: "B", score: 4, answers: [ { q: 1, a: 0 }, { q: 2, a: 8 } ] }
]
2.3. Operators 443
MongoDB Reference Manual, Release 2.6.4
}
Then you can specify multiple conditions on the elements of the answers array with $elemMatch (page 421):
db.survey.update(
{ },
{ $pull: { results: { answers: { $elemMatch: { q: 2, a: { $gte: 8 } } } } } },
{ multi: true }
)
The operation removed from the results array those embedded documents with an answers eld that contained
at least one element with q equal to 2 and a greater than or equal to 8:
{
"_id" : 1,
"results" : [
{ "item" : "A", "score" : 5, "answers" : [ { "q" : 1, "a" : 4 }, { "q" : 2, "a" : 6 } ] }
]
}
{
"_id" : 2,
"results" : [
{ "item" : "C", "score" : 8, "answers" : [ { "q" : 1, "a" : 8 }, { "q" : 2, "a" : 7 } ] }
]
}
$pushAll
$pushAll
Deprecated since version 2.4: Use the $push (page 444) operator with $each (page 446) instead.
The $pushAll (page 444) operator is similar to the $push (page 444) but adds the ability to append several
values to an array at once.
db.collection.update( { field: value }, { $pushAll: { field1: [ value1, value2, value3 ] } } );
Here, $pushAll (page 444) appends the values in [ value1, value2, value3 ] to the array in
field1 in the document matched by the statement { field: value } in collection.
If you specify a single value, $pushAll (page 444) will behave as $push (page 444).
$push
$push
The $push (page 444) operator appends a specied value to an array.
db.collection.update( <query>,
{ $push: { <field>: <value> } }
)
The following example appends 89 to the scores array for the rst document where the _id eld equals 1:
db.students.update(
{ _id: 1 },
{ $push: { scores: 89 } }
)
Note:
444 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
If the eld is absent in the document to update, $push (page 444) adds the array eld with the value as its
element.
If the eld is not an array, the operation will fail.
If the value is an array, $push (page 444) appends the whole array as a single element. To add each
element of the value separately, use $push (page 444) with the $each (page 446) modier.
Changed in version 2.4: MongoDB adds support for the $each (page 446) modier to the $push
(page 444) operator. Before 2.4, use $pushAll (page 444) for similar functionality.
The following example appends each element of [ 90, 92, 85 ] to the scores array for the docu-
ment where the name eld equals joe:
db.students.update(
{ name: "joe" },
{ $push: { scores: { $each: [ 90, 92, 85 ] } } }
)
Modiers New in version 2.4.
You can use the $push (page 444) operator with the following modiers:
$each (page 446) appends multiple values to the array eld,
Changed in version 2.6: When used in conjunction with the other modiers, the $each (page 446) modier no
longer needs to be rst.
$slice (page 449), which is only available when used with $each (page 446), limits the number of array
elements,
$sort (page 451), which is only available when used with $each (page 446), orders elements of the array,
and
Changed in version 2.6: In previous versions, $sort (page 451) is only available when used with both $each
(page 446) and $slice (page 449).
$position (page 447), which is only available when used with $each (page 446), species the location
in the array at which to insert the new elements. Without the $position (page 447) modier, the $push
(page 444) appends the elements to the end of the array.
New in version 2.6.
The processing of the push operation with modiers occur in the following order, regardless of the order in which
the modiers appear:
1. Update array to add elements in the correct position.
2. Apply sort, if specied.
3. Slice the array, if specied.
4. Store the array.
Examples
Use $push Operator with Multiple Modiers A collection students has the following document:
2.3. Operators 445
MongoDB Reference Manual, Release 2.6.4
{
"_id" : 5,
"quizzes" : [
{ wk: 1, "score" : 10 },
{ wk: 2, "score" : 8 },
{ wk: 3, "score" : 5 },
{ wk: 4, "score" : 6 }
]
}
The following $push (page 444) operation uses:
the $each (page 446) modier to add multiple documents to the quizzes array,
the $sort (page 451) modier to sort all the elements of the modied quizzes array by the score eld in
descending order, and
the $slice (page 449) modier to keep only the rst three sorted elements of the quizzes array.
db.students.update( { _id: 5 },
{ $push: { quizzes: { $each: [ { wk: 5, score: 8 },
{ wk: 6, score: 7 },
{ wk: 7, score: 6 } ],
$sort: { score: -1 },
$slice: 3
}
}
}
)
The result of the operation is keep only the three highest scoring quizzes:
{ "_id" : 5,
"quizzes" : [
{ "wk" : 1, "score" : 10 },
{ "wk" : 2, "score" : 8 },
{ "wk" : 5, "score" : 8 }
]
}
Update Operator Modiers
Name Description
$each (page 446) Modies the $push (page 444) and $addToSet (page 439) operators to append multiple
items for array updates.
$position
(page 447)
Modies the $push (page 444) operator to specify the position in the array to add
elements.
$slice
(page 449)
Modies the $push (page 444) operator to limit the size of updated arrays.
$sort (page 451) Modies the $push (page 444) operator to reorder documents stored in an array.
$each
$each
The $each (page 446) modier is available for use with the $addToSet (page 439) operator and the $push
(page 444) operator.
Use the $each (page 446) modier with the $addToSet (page 439) operator to add multiple values to an
array <field> if the values do not exist in the <field>.
446 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.update( <query>,
{
$addToSet: { <field>: { $each: [ <value1>, <value2> ... ] } }
}
)
Use the $each (page 446) modier with the $push (page 444) operator to append multiple values to an array
<field>.
db.collection.update( <query>,
{
$push: { <field>: { $each: [ <value1>, <value2> ... ] } }
}
)
Changed in version 2.4: MongoDB adds support for the $each (page 446) modier to the $push (page 444)
operator. The $push (page 444) operator can use $each (page 446) modier with other modiers. See $push
(page 444) for details.
Examples
Use $each with $push Operator The following example appends each element of [ 90, 92, 85 ] to the
scores array for the document where the name eld equals joe:
db.students.update(
{ name: "joe" },
{ $push: { scores: { $each: [ 90, 92, 85 ] } } }
)
Use $each with $addToSet Operator A collection inventory has the following document:
{ _id: 2, item: "cable", tags: [ "electronics", "supplies" ] }
Then the following operation uses the $addToSet (page 439) operator with the $each (page 446) modier to add
multiple elements to the tags array:
db.inventory.update(
{ _id: 2 },
{ $addToSet: { tags: { $each: [ "camera",
"electronics",
"accessories" ] } } }
)
The operation adds only "camera" and "accessories" to the tags array since "electronics" already
exists in the array:
{ _id: 2,
item: "cable",
tags: [ "electronics", "supplies", "camera", "accessories" ] }
$position
$position
New in version 2.6.
2.3. Operators 447
MongoDB Reference Manual, Release 2.6.4
The $position (page 447) modier species the location in the array at which the $push (page 444) operator
insert elements. Without the $position (page 447) modier, the $push (page 444) operator inserts elements
to the end of the array. See $push modiers (page 445) for more information.
To use the $position (page 447) modier, it must appear with the $each (page 446) modier.
db.collection.update( <query>,
{ $push: {
<field>: {
$each: [ <value1>, <value2>, ... ],
$position: <num>
}
}
}
)
The <num> is a non-negative number that corresponds to the position in the array, based on a zero-based index.
If the number is greater or equal to the length of the array, the $position (page 447) modier has no effect
and the operator adds elements to the end of the array.
Examples
Add Elements at the Start of the Array Consider a collection students that contains the following document:
{ "_id" : 1, "scores" : [ 100 ] }
The following operation updates the scores eld to add the elements 50, 60 and 70 to the beginning of the array:
db.students.update( { _id: 1 },
{ $push: { scores: {
$each: [ 50, 60, 70 ],
$position: 0
}
}
}
)
The operation results in the following updated document:
{ "_id" : 1, "scores" : [ 50, 60, 70, 100 ] }
Add Elements to the Middle of the Array Consider a collection students that contains the following document:
{ "_id" : 1, "scores" : [ 50, 60, 70, 100 ] }
The following operation updates the scores eld to add the elements 20 and 30 at the array index of 2:
db.students.update( { _id: 1 },
{ $push: { scores: {
$each: [ 20, 30 ],
$position: 2
}
}
}
)
The operation results in the following updated document:
448 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 1, "scores" : [ 50, 60, 20, 30, 70, 100 ] }
$slice
$slice
New in version 2.4.
The $slice (page 449) modier limits the number of array elements during a $push (page 444) operation.
To project, or return, a specied number of array elements from a read operation, see the $slice (page 428)
projection operator instead.
To use the $slice (page 449) modier, it must appear with the $each (page 446) modier.
Tip
You can pass an empty array [] to the $each (page 446) modier such that only the $slice (page 449)
modier has an effect.
Changed in version 2.6: The $slice (page 449) can slice from the beginning of the array. Trying to use
the $slice (page 449) modier without the $each (page 446) modier results in an error. The order in
which the modiers appear is immaterial. Previous versions required the $each (page 446) modier to
appear as the rst modier if used in conjunction with $slice (page 449).
db.collection.update( <query>,
{ $push: {
<field>: {
$each: [ <value1>, <value2>, ... ],
$slice: <num>
}
}
}
)
The <num> can be:
zero to update the array <field> to an empty array,
negative to update the array <field> to contain only the last <num> elements, or
positive to update the array <field> contain only the rst <num> elements.
New in version 2.6.
Examples
Slice from the End of the Array A collection students contains the following document:
{ "_id" : 1, "scores" : [ 40, 50, 60 ] }
The following operation adds new elements to the scores array, and then uses the $slice (page 449) modier to
trim the array to the last ve elements:
db.students.update( { _id: 1 },
{ $push: { scores: {
$each: [ 80, 78, 86 ],
$slice: -5
}
}
2.3. Operators 449
MongoDB Reference Manual, Release 2.6.4
}
)
The result of the operation is slice the elements of the updated scores array to the last ve elements:
{ "_id" : 1, "scores" : [ 50, 60, 80, 78, 86 ] }
Slice from the Front of the Array A collection students contains the following document:
{ "_id" : 2, "scores" : [ 89, 90 ] }
The following operation adds new elements to the scores array, and then uses the $slice (page 449) modier to
trim the array to the rst three elements.
db.students.update( { _id: 2 },
{ $push: { scores: { $each: [ 100, 20 ], $slice: 3 } } }
)
The result of the operation is to slice the elements of the updated scores array to the rst three elements:
{ "_id" : 2, "scores" : [ 89, 90, 100 ] }
Update Array Using Slice Only A collection students contains the following document:
{ "_id" : 3, "scores" : [ 89, 70, 100, 20 ] }
To update the scores eld with just the effects of the $slice (page 449) modier, specify the number of elements
to slice (e.g. -3) for the $slice (page 449) modier and an empty array [] for the $each (page 446) modier, as
in the following:
db.students.update(
{ _id: 3 },
{ $push: { scores: { $each: [ ], $slice: -3 } } }
)
The result of the operation is to slice the elements of the scores array to the last three elements:
{ "_id" : 3, "scores" : [ 70, 100, 20 ] }
Use $slice with Other $push Modiers A collection students has the following document:
{
"_id" : 5,
"quizzes" : [
{ wk: 1, "score" : 10 },
{ wk: 2, "score" : 8 },
{ wk: 3, "score" : 5 },
{ wk: 4, "score" : 6 }
]
}
The following $push (page 444) operation uses:
the $each (page 446) modier to add multiple documents to the quizzes array,
the $sort (page 451) modier to sort all the elements of the modied quizzes array by the score eld in
descending order, and
450 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
the $slice (page 449) modier to keep only the rst three sorted elements of the quizzes array.
db.students.update( { _id: 5 },
{ $push: { quizzes: { $each: [ { wk: 5, score: 8 },
{ wk: 6, score: 7 },
{ wk: 7, score: 6 } ],
$sort: { score: -1 },
$slice: 3
}
}
}
)
The result of the operation is keep only the three highest scoring quizzes:
{ "_id" : 5,
"quizzes" : [
{ "wk" : 1, "score" : 10 },
{ "wk" : 2, "score" : 8 },
{ "wk" : 5, "score" : 8 }
]
}
The order of the modiers is immaterial to the order in which the modiers are processed. See Modiers (page 445)
for details.
$sort
$sort
New in version 2.4.
The $sort (page 451) modier orders the elements of an array during a $push (page 444) operation.
To use the $sort (page 451) modier, it must appear with the $each (page 446) modier.
Tip
You can pass an empty array [] to the $each (page 446) modier such that only the $sort (page 451)
modier has an effect.
Changed in version 2.6: The $sort (page 451) modier can sort array elements that are not documents.
In previous versions, the $sort (page 451) modier required the array elements be documents. If the
array elements are documents, the modier can sort by either the whole document or by a specic eld in
the documents. In previous versions, the $sort (page 451) modier can only sort by a specic eld in
the documents. The $sort (page 451) no longer requires the $slice (page 449) modier. Trying to
use the $sort (page 451) modier without the $each (page 446) modier results in an error.
db.collection.update( <query>,
{ $push: {
<arrayField>: {
$each: [ <value1>,
<value2>,
...
],
$sort: <sort specification>,
}
}
}
)
2.3. Operators 451
MongoDB Reference Manual, Release 2.6.4
For <sort specification>:
To sort array elements that are not documents, or if the array elements are documents, to sort by the whole
documents, specify 1 for ascending or -1 for descending.
If the array elements are documents, to sort by a eld in the documents, specify a sort document with the
eld and the direction, i.e. { field: 1 } or { field: -1 }. Do not reference the containing
array eld in the sort specication (e.g. { "arrayField.field": 1 } is incorrect).
Examples
Sort Array of Documents by a Field in the Documents A collection students contains the following document:
{ "_id": 1,
"quizzes": [
{ "id" : 1, "score" : 6 },
{ "id" : 2, "score" : 9 }
]
}
The following update appends additional documents to the quizzes array and then sorts all the elements of the array
by the ascending score eld:
db.students.update( { _id: 1 },
{ $push: { quizzes: { $each: [ { id: 3, score: 8 },
{ id: 4, score: 7 },
{ id: 5, score: 6 } ],
$sort: { score: 1 },
}
}
}
)
Important: The sort document refers directly to the eld in the documents and does not reference the containing
array eld quizzes; i.e. { score: 1 } and not { "quizzes.score": 1}
After the update, the array elements are in order of ascending score eld.:
{
"_id" : 1,
"quizzes" : [
{ "id" : 1, "score" : 6 },
{ "id" : 5, "score" : 6 },
{ "id" : 4, "score" : 7 },
{ "id" : 3, "score" : 8 },
{ "id" : 2, "score" : 9 }
]
}
Sort Array Elements That Are Not Documents A collection students contains the following document:
{ "_id" : 2, "tests" : [ 89, 70, 89, 50 ] }
The following operation adds two more elements to the scores array and sorts the elements:
452 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.students.update(
{ _id: 2 },
{ $push: { tests: { $each: [ 40, 60 ], $sort: 1 } } }
)
The updated document has the elements of the scores array in ascending order:
{ "_id" : 2, "tests" : [ 40, 50, 60, 70, 89, 89 ] }
Update Array Using Sort Only A collection students contains the following document:
{ "_id" : 3, "tests" : [ 89, 70, 100, 20 ] }
To update the tests eld to sort its elements in descending order, specify the { $sort: -1 } and specify an
empty array [] for the $each (page 446) modier, as in the following:
db.students.update(
{ _id: 3 },
{ $push: { tests: { $each: [ ], $sort: -1 } } }
)
The result of the operation is to update the scores eld to sort its elements in descending order:
{ "_id" : 3, "tests" : [ 100, 89, 70, 20 ] }
Use $sort with Other $push Modiers A collection students has the following document:
{
"_id" : 5,
"quizzes" : [
{ wk: 1, "score" : 10 },
{ wk: 2, "score" : 8 },
{ wk: 3, "score" : 5 },
{ wk: 4, "score" : 6 }
]
}
The following $push (page 444) operation uses:
the $each (page 446) modier to add multiple documents to the quizzes array,
the $sort (page 451) modier to sort all the elements of the modied quizzes array by the score eld in
descending order, and
the $slice (page 449) modier to keep only the rst three sorted elements of the quizzes array.
db.students.update( { _id: 5 },
{ $push: { quizzes: { $each: [ { wk: 5, score: 8 },
{ wk: 6, score: 7 },
{ wk: 7, score: 6 } ],
$sort: { score: -1 },
$slice: 3
}
}
}
)
The result of the operation is keep only the three highest scoring quizzes:
2.3. Operators 453
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 5,
"quizzes" : [
{ "wk" : 1, "score" : 10 },
{ "wk" : 2, "score" : 8 },
{ "wk" : 5, "score" : 8 }
]
}
The order of the modiers is immaterial to the order in which the modiers are processed. See Modiers (page 445)
for details.
Bitwise
Bitwise Update Operator
Name Description
$bit (page 454) Performs bitwise AND, OR, and XOR updates of integer values.
$bit
$bit
Changed in version 2.6: Added support for bitwise xor operation.
The $bit (page 454) operator performs a bitwise update of a eld. The $bit (page 454) operator supports
bitwise and, bitwise or, and bitwise xor (i.e. exclusive or) operations. To specify a $bit (page 454) operator
expression, use the following prototype:
{ $bit: { field: { <and|or|xor>: <int> } } }
Only use this operator with integer elds (either 32-bit integer or 64-bit integer).
Note: All numbers in the mongo (page 580) shell are doubles, not integers. Use the NumberInt() or the
NumberLong() constructor to specify integers. See shell-type-int or shell-type-long for more information.
Examples
Bitwise AND Consider the following document inserted into the collection switches:
{ _id: 1, expdata: NumberInt(13) }
The following update() (page 70) operation updates the expdata eld to the result of a bitwise and operation
between the current value NumberInt(13) (i.e. 1101) and NumberInt(10) (i.e. 1010):
db.switches.update(
{ _id: 1 },
{ $bit: { expdata: { and: NumberInt(10) } } }
)
The bitwise and operation results in the integer 8 (i.e. 1000):
1101
1010
----
1000
And the updated document has the following value for expdata:
454 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "_id" : 1, "expdata" : 8 }
The mongo (page 580) shell displays NumberInt(8) as 8.
Bitwise OR Consider the following document inserted into the collection switches:
{ _id: 2, expdata: NumberLong(3) }
The following update() (page 70) operation updates the expdata eld to the result of a bitwise or operation
between the current value NumberLong(3) (i.e. 0011) and NumberInt(5) (i.e. 0101):
db.switches.update(
{ _id: 2 },
{ $bit: { expdata: { or: NumberInt(5) } } }
)
The bitwise or operation results in the integer 7 (i.e. 0111):
0011
0101
----
0111
And the updated document has the following value for expdata:
{ "_id" : 2, "expdata" : NumberLong(7) }
Bitwise XOR Consider the following document in the collection switches:
{ _id: 3, expdata: NumberLong(1) }
The following update() (page 70) operation updates the expdata eld to the result of a bitwise xor operation
between the current value NumberLong(1) (i.e. 0001) and NumberInt(5) (i.e. 0101):
db.switches.update(
{ _id: 3 },
{ $bit: { expdata: { xor: NumberInt(5) } } }
)
The bitwise xor operation results in the integer 4:
0001
0101
----
0100
And the updated document has the following value for expdata:
{ "_id" : 3, "expdata" : NumberLong(4) }
Isolation
Isolation Update Operator
Name Description
$isolated (page 456) Modies the behavior of a write operation to increase the isolation of the operation.
2.3. Operators 455
MongoDB Reference Manual, Release 2.6.4
$isolated
$isolated
Prevents a write operation that affects multiple documents from yielding to other reads or writes once the rst
document is written. By using the $isolated (page 456) option, you can ensure that no client sees the
changes until the operation completes or errors out.
This behavior can signicantly affect the concurrency of the system as the operation holds the write lock much
longer than normal.
Note: The $isolated (page 456) isolation operator does not provide all-or-nothing atomicity for write
operations.
Consider the following example:
db.foo.update(
{ status : "A" , $isolated : 1 },
{ $inc : { count : 1 } },
{ multi: true }
)
Without the $isolated (page 456) operator, the multi-update operation will allow other operations to in-
terleave with its update of the matched documents.
Warning: $isolated (page 456) does not work with sharded clusters.
See also:
db.collection.update() (page 70) and db.collection.remove() (page 64)
$atomic
Deprecated since version 2.2: The $isolated (page 456) operator replaces $atomic.
2.3.3 Aggregation Pipeline Operators
Stage Operators
Pipeline stages appear in an array. Documents pass through the stages in sequence.
db.collection.aggregate( [ { <stage> }, ... ] )
456 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Name Description
$geoNear
(page 458)
Returns an ordered stream of documents based on the proximity to a geospatial point.
Incorporates the functionality of $match (page 464), $sort (page 473), and $limit
(page 463) for geospatial data. The output documents include an additional distance eld and can
include a location identier eld.
$group
(page 460)
Groups input documents by a specied identier expression and applies the accumulator
expression(s), if specied, to each group. Consumes all input documents and outputs one
document per each distinct group. The output documents only contain the identier eld and, if
specied, accumulated elds.
$limit
(page 463)
Passes the rst n documents unmodied to the pipeline where n is the specied limit. For each
input document, outputs either one document (for the rst n documents) or zero documents (after
the rst n documents).
$match
(page 464)
Filters the document stream to allow only matching documents to pass unmodied into the next
pipeline stage. $match (page 464) uses standard MongoDB queries. For each input document,
outputs either one document (a match) or zero documents (no match).
$out
(page 465)
Writes the resulting documents of the aggregation pipeline to a collection. To use the $out
(page 465) stage, it must be the last stage in the pipeline.
$project
(page 466)
Reshapes each document in the stream, such as by adding new elds or removing existing elds.
For each input document, outputs one document.
$redact
(page 469)
Reshapes each document in the stream by restricting the content for each document based on
information stored in the documents themselves. Incorporates the functionality of $project
(page 466) and $match (page 464). Can be used to implement eld level redaction. For each
input document, outputs either one or zero document.
$skip
(page 473)
Skips the rst n documents where n is the specied skip number and passes the remaining
documents unmodied to the pipeline. For each input document, outputs either zero documents
(for the rst n documents) or one document (if after the rst n documents).
$sort
(page 473)
Reorders the document stream by a specied sort key. Only the order changes; the documents
remain unmodied. For each input document, outputs one document.
$unwind
(page 475)
Deconstructs an array eld from the input documents to output a document for each element.
Each output document replaces the array with an element value. For each input document,
outputs n documents where n is the number of array elements and can be zero for an empty array.
2.3. Operators 457
MongoDB Reference Manual, Release 2.6.4
Pipeline Aggregation Stages
Name Description
$geoNear
(page 458)
Returns an ordered stream of documents based on the proximity to a geospatial point.
Incorporates the functionality of $match (page 464), $sort (page 473), and $limit
(page 463) for geospatial data. The output documents include an additional distance eld and can
include a location identier eld.
$group
(page 460)
Groups input documents by a specied identier expression and applies the accumulator
expression(s), if specied, to each group. Consumes all input documents and outputs one
document per each distinct group. The output documents only contain the identier eld and, if
specied, accumulated elds.
$limit
(page 463)
Passes the rst n documents unmodied to the pipeline where n is the specied limit. For each
input document, outputs either one document (for the rst n documents) or zero documents (after
the rst n documents).
$match
(page 464)
Filters the document stream to allow only matching documents to pass unmodied into the next
pipeline stage. $match (page 464) uses standard MongoDB queries. For each input document,
outputs either one document (a match) or zero documents (no match).
$out
(page 465)
Writes the resulting documents of the aggregation pipeline to a collection. To use the $out
(page 465) stage, it must be the last stage in the pipeline.
$project
(page 466)
Reshapes each document in the stream, such as by adding new elds or removing existing elds.
For each input document, outputs one document.
$redact
(page 469)
Reshapes each document in the stream by restricting the content for each document based on
information stored in the documents themselves. Incorporates the functionality of $project
(page 466) and $match (page 464). Can be used to implement eld level redaction. For each
input document, outputs either one or zero document.
$skip
(page 473)
Skips the rst n documents where n is the specied skip number and passes the remaining
documents unmodied to the pipeline. For each input document, outputs either zero documents
(for the rst n documents) or one document (if after the rst n documents).
$sort
(page 473)
Reorders the document stream by a specied sort key. Only the order changes; the documents
remain unmodied. For each input document, outputs one document.
$unwind
(page 475)
Deconstructs an array eld from the input documents to output a document for each element.
Each output document replaces the array with an element value. For each input document,
outputs n documents where n is the number of array elements and can be zero for an empty array.
$geoNear (aggregation)
Denition
$geoNear
New in version 2.4.
Outputs documents in order of nearest to farthest from a specied point.
The $geoNear (page 458) stage has the following prototype form:
{ $geoNear: { <geoNear options> } }
The $geoNear (page 458) operator accepts a document that contains the following $geoNear (page 458)
options. Specify all distances in the same units as those of the processed documents coordinate system:
:eld GeoJSON point,:term:legacy coordinate pairs <legacy coordinate pairs> near:
The point for which to nd the closest documents.
eld string distanceField The output eld that contains the calculated distance. To specify a eld
within a subdocument, use dot notation.
458 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
eld number limit The maximum number of documents to return. The default value is 100. See
also the num option.
eld number num The num option provides the same function as the limit option. Both dene
the maximum number of documents to return. If both options are included, the num value
overrides the limit value.
eld number maxDistance The maximum distance from the center point that the documents can
be. MongoDB limits the results to those documents that fall within the specied distance from
the center point.
Specify the distance in meters for GeoJSON data and in radians for legacy coordinate pairs.
eld document query Limits the results to the documents that match the query. The query syntax
is the usual MongoDB read operation query syntax.
You cannot specify a $near (page 410) predicate in the query eld of the $geoNear
(page 458) stage.
eld Boolean spherical Required if using a 2dsphere index. For use with 2dsphere indexes,
spherical must be true.
The default value is false.
eld number distanceMultiplier The factor to multiply all distances returned by the query. For
example, use the distanceMultiplier to convert radians, as returned by a spherical query,
to kilometers by multiplying by the radius of the Earth.
eld string includeLocs This species the output eld that identies the location used to calculate
the distance. This option is useful when a location eld contains multiple locations. To specify
a eld within a subdocument, use dot notation.
eld Boolean uniqueDocs If this value is true, the query returns a matching document once, even
if more than one of the documents location elds match the query.
Deprecated since version 2.6: Geospatial queries no longer return duplicate results. The
$uniqueDocs (page 416) operator has no impact on results.
Behavior When using $geoNear (page 458), consider that:
You can only use $geoNear (page 458) as the rst stage of a pipeline.
You must include the distanceField option. The distanceField option species the eld that will
contain the calculated distance.
The collection must have a geospatial index.
The $geoNear (page 458) requires that a collection have at most only one 2d index and/or only one
2dsphere index.
If using a 2dsphere index, you must specify spherical: true.
You cannot specify a $near (page 410) predicate in the query eld of the $geoNear (page 458) stage.
Generally, the options for $geoNear (page 458) are similar to the geoNear (page 227) command with the following
exceptions:
distanceField is a mandatory eld for the $geoNear (page 458) pipeline operator; the option does not
exist in the geoNear (page 227) command.
includeLocs accepts a string in the $geoNear (page 458) pipeline operator and a boolean in the
geoNear (page 227) command.
2.3. Operators 459
MongoDB Reference Manual, Release 2.6.4
Example Consider a collection places that has a 2dsphere index. The following aggregation nds at most
5 unique documents with a location at most 2 units from the center [ -73.99279 , 40.719296 ] and have
type equal to public:
db.places.aggregate([
{
$geoNear: {
near: { type: "Point", coordinates: [ -73.99279 , 40.719296 ] },
distanceField: "dist.calculated",
maxDistance: 2,
query: { type: "public" },
includeLocs: "dist.location",
num: 5,
spherical: true
}
}
])
The aggregation returns the following:
{
"_id" : 8,
"name" : "Sara D. Roosevelt Park",
"type" : "public",
"location" : {
"type" : "Point",
"coordinates" : [ -73.9928, 40.7193 ]
},
"dist" : {
"calculated" : 0.9539931676365992,
"location" : {
"type" : "Point",
"coordinates" : [ -73.9928, 40.7193 ]
}
}
}
The matching document contains two new elds:
dist.calculated eld that contains the calculated distance, and
dist.location eld that contains the location used in the calculation.
$group (aggregation)
$group
Groups documents by some specied expression and outputs to the next stage a document for each distinct
grouping. The output documents contain an _id eld which contains the distinct group by key. The output
documents can also contain computed elds that hold the values of some accumulator expression grouped by
the $group (page 460)s _id eld. $group (page 460) does not order its output documents.
The $group (page 460) stage has the following prototype form:
{ $group: { _id: <expression>, <field1>: { <accumulator1> : <expression1> }, ... } }
The _id eld is mandatory; however, you can specify an _id value of null to calculate accumulated values for
all the input documents as a whole.
The remaining computed elds are optional and computed using the <accumulator> operators.
460 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The _id and the <accumulator> expressions can accept any valid expression (page 537). For more infor-
mation on expressions, see Expressions (page 537).
Accumulator Operator The <accumulator> operator must be one of the following accumulator operators:
Name Description
$addToSet
(page 521)
Returns an array of unique expression values for each group. Order of the array elements is
undened.
$avg (page 522) Returns an average for each group. Ignores non-numeric values.
$first
(page 522)
Returns a value from the rst document for each group. Order is only dened if the
documents are in a dened order.
$last (page 523) Returns a value from the last document for each group. Order is only dened if the
documents are in a dened order.
$max (page 524) Returns the highest expression value for each group.
$min (page 525) Returns the lowest expression value for each group.
$push (page 526) Returns an array of expression values for each group.
$sum (page 527) Returns a sum for each group. Ignores non-numeric values.
$group Operator and Memory The $group (page 460) stage has a limit of 100 megabytes of RAM. By default,
if the stage exceeds this limit, $group (page 460) will produce an error. However, to allow for the handling of
large datasets, set the allowDiskUse (page 22) option to true to enable $group (page 460) operations to write
to temporary les. See db.collection.aggregate() (page 22) method and the aggregate (page 208)
command for details.
Changed in version 2.6: MongoDB introduces a limit of 100 megabytes of RAM for the $group (page 460) stage as
well as the allowDiskUse (page 22) option to handle operations for large datasets.
Examples
Calculate Count, Sum, and Average Given a collection sales with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-03-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-03-01T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-03-15T09:00:00Z") }
{ "_id" : 4, "item" : "xyz", "price" : 5, "quantity" : 20, "date" : ISODate("2014-04-04T11:21:39.736Z") }
{ "_id" : 5, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-04-04T21:23:13.331Z") }
Group by Month, Day, and Year The following aggregation operation uses the $group (page 460) stage to group
the documents by the month, day, and year and calculates the total price and the average quantity as well as counts the
documents per each group:
db.sales.aggregate(
[
{
$group : {
_id : { month: { $month: "$date" }, day: { $dayOfMonth: "$date" }, year: { $year: "$date" } },
totalPrice: { $sum: { $multiply: [ "$price", "$quantity" ] } },
averageQuantity: { $avg: "$quantity" },
count: { $sum: 1 }
}
}
]
)
2.3. Operators 461
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "_id" : { "month" : 3, "day" : 15, "year" : 2014 }, "totalPrice" : 50, "averageQuantity" : 10, "count" : 1 }
{ "_id" : { "month" : 4, "day" : 4, "year" : 2014 }, "totalPrice" : 200, "averageQuantity" : 15, "count" : 2 }
{ "_id" : { "month" : 3, "day" : 1, "year" : 2014 }, "totalPrice" : 40, "averageQuantity" : 1.5, "count" : 2 }
Group by null The following aggregation operation species a group _id of null, calculating the total price
and the average quantity as well as counts for all documents in the collection:
db.sales.aggregate(
[
{
$group : {
_id : null,
totalPrice: { $sum: { $multiply: [ "$price", "$quantity" ] } },
averageQuantity: { $avg: "$quantity" },
count: { $sum: 1 }
}
}
]
)
The operation returns the following result:
{ "_id" : null, "totalPrice" : 290, "averageQuantity" : 8.6, "count" : 5 }
Retrieve Distinct Values Given a collection sales with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-03-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-03-01T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-03-15T09:00:00Z") }
{ "_id" : 4, "item" : "xyz", "price" : 5, "quantity" : 20, "date" : ISODate("2014-04-04T11:21:39.736Z") }
{ "_id" : 5, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-04-04T21:23:13.331Z") }
The following aggregation operation uses the $group (page 460) stage to group the documents by the item to retrieve
the distinct item values:
db.sales.aggregate( [ { $group : { _id : "$item" } } ] )
The operation returns the following result:
{ "_id" : "xyz" }
{ "_id" : "jkl" }
{ "_id" : "abc" }
Pivot Data A collection books contains the following documents:
{ "_id" : 8751, "title" : "The Banquet", "author" : "Dante", "copies" : 2 }
{ "_id" : 8752, "title" : "Divine Comedy", "author" : "Dante", "copies" : 1 }
{ "_id" : 8645, "title" : "Eclogues", "author" : "Dante", "copies" : 2 }
{ "_id" : 7000, "title" : "The Odyssey", "author" : "Homer", "copies" : 10 }
{ "_id" : 7020, "title" : "Iliad", "author" : "Homer", "copies" : 10 }
Group title by author The following aggregation operation pivots the data in the books collection to have
titles grouped by authors.
462 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.books.aggregate(
[
{ $group : { _id : "$author", books: { $push: "$title" } } }
]
)
The operation returns the following documents:
{ "_id" : "Homer", "books" : [ "The Odyssey", "Iliad" ] }
{ "_id" : "Dante", "books" : [ "The Banquet", "Divine Comedy", "Eclogues" ] }
Group Documents by author The following aggregation operation uses the $$ROOT (page 546) system vari-
able to group the documents by authors. The resulting documents must not exceed the BSON Document Size
(page 658) limit.
db.books.aggregate(
[
{ $group : { _id : "$author", books: { $push: "$$ROOT" } } }
]
)
The operation returns the following documents:
{
"_id" : "Homer",
"books" :
[
{ "_id" : 7000, "title" : "The Odyssey", "author" : "Homer", "copies" : 10 },
{ "_id" : 7020, "title" : "Iliad", "author" : "Homer", "copies" : 10 }
]
}
{
"_id" : "Dante",
"books" :
[
{ "_id" : 8751, "title" : "The Banquet", "author" : "Dante", "copies" : 2 },
{ "_id" : 8752, "title" : "Divine Comedy", "author" : "Dante", "copies" : 1 },
{ "_id" : 8645, "title" : "Eclogues", "author" : "Dante", "copies" : 2 }
]
}
$limit (aggregation)
Denition
$limit
Limits the number of documents passed to the next stage in the pipeline.
The $limit (page 463) stage has the following prototype form:
{ $limit: <positive integer> }
$limit (page 463) takes a positive integer that species the maximum number of documents to pass along.
2.3. Operators 463
MongoDB Reference Manual, Release 2.6.4
Example Consider the following example:
db.article.aggregate(
{ $limit : 5 }
);
This operation returns only the rst 5 documents passed to it from by the pipeline. $limit (page 463) has no effect
on the content of the documents it passes.
Note: When a $sort (page 473) immediately precedes a $limit (page 463) in the pipeline, the $sort (page 473)
operation only maintains the top n results as it progresses, where n is the specied limit, and MongoDB only needs to
store n items in memory. This optimization still applies when allowDiskUse is true and the n items exceed the
aggregation memory limit.
Changed in version 2.4: Before MongoDB 2.4, $sort (page 473) would sort all the results in memory, and then limit
the results to n results.
$match (aggregation)
Denition
$match
Filters the documents to pass only the documents that match the specied condition(s) to the next pipeline stage.
The $match (page 464) stage has the following prototype form:
{ $match: { <query> } }
$match (page 464) takes a document that species the query conditions. The query syntax is identical to the
read operation query syntax.
Behavior
Pipeline Optimization
Place the $match (page 464) as early in the aggregation pipeline as possible. Because $match (page 464) lim-
its the total number of documents in the aggregation pipeline, earlier $match (page 464) operations minimize
the amount of processing down the pipe.
If you place a $match (page 464) at the very beginning of a pipeline, the query can take advantage of indexes
like any other db.collection.find() (page 33) or db.collection.findOne() (page 42).
Restrictions
You cannot use $where (page 404) in $match (page 464) queries as part of the aggregation pipeline.
To use $text (page 401) in the $match (page 464) stage, the $match (page 464) stage has to be the rst
stage of the pipeline.
Examples
Equality Match The following operation uses $match (page 464) to perform a simple equality match:
464 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.articles.aggregate(
[ { $match : { author : "dave" } } ]
);
The $match (page 464) selects the documents where the author eld equals dave, and the aggregation returns the
following:
{
"result" : [
{
"_id" : ObjectId("512bc95fe835e68f199c8686"),
"author": "dave",
"score" : 80
},
{ "_id" : ObjectId("512bc962e835e68f199c8687"),
"author" : "dave",
"score" : 85
}
],
"ok" : 1
}
Perform a Count The following example selects documents to process using the $match (page 464) pipeline
operator and then pipes the results to the $group (page 460) pipeline operator to compute a count of the documents:
db.articles.aggregate( [
{ $match : { score : { $gt : 70, $lte : 90 } } },
{ $group: { _id: null, count: { $sum: 1 } } }
] );
In the aggregation pipeline, $match (page 464) selects the documents where the score is greater than 70 and less
than or equal to 90. These documents are then piped to the $group (page 460) to perform a count. The aggregation
returns the following:
{
"result" : [
{
"_id" : null,
"count" : 3
}
],
"ok" : 1
}
$out (aggregation) New in version 2.6.
Denition
$out
Takes the documents returned by the aggregation pipeline and writes them to a specied collection. The $out
(page 465) operator must be the last stage in the pipeline. The $out (page 465) operator lets the aggregation
framework return result sets of any size.
The $out (page 465) stage has the following prototype form:
{ $out: "<output-collection>" }
2.3. Operators 465
MongoDB Reference Manual, Release 2.6.4
$out (page 465) takes a string that species the output collection name.
Important:
You cannot specify a sharded collection as the output collection. The input collection for a pipeline can be
sharded.
The $out (page 465) operator cannot write results to a capped collection.
Behaviors
Create New Collection The $out (page 465) operation creates a new collection in the current database if one does
not already exist. The collection is not visible until the aggregation completes. If the aggregation fails, MongoDB
does not create the collection.
Replace Existing Collection If the collection specied by the $out (page 465) operation already exists, then upon
completion of the aggregation, the $out (page 465) stage atomically replaces the existing collection with the new
results collection. The $out (page 465) operation does not change any indexes that existed on the previous collection.
If the aggregation fails, the $out (page 465) operation makes no changes to the pre-existing collection.
Index Constraints The pipeline will fail to complete if the documents produced by the pipeline would violate any
unique indexes, including the index on the _id eld of the original output collection.
Example A collection books contains the following documents:
{ "_id" : 8751, "title" : "The Banquet", "author" : "Dante", "copies" : 2 }
{ "_id" : 8752, "title" : "Divine Comedy", "author" : "Dante", "copies" : 1 }
{ "_id" : 8645, "title" : "Eclogues", "author" : "Dante", "copies" : 2 }
{ "_id" : 7000, "title" : "The Odyssey", "author" : "Homer", "copies" : 10 }
{ "_id" : 7020, "title" : "Iliad", "author" : "Homer", "copies" : 10 }
The following aggregation operation pivots the data in the books collection to have titles grouped by authors and
then writes the results to the authors collection.
db.books.aggregate( [
{ $group : { _id : "$author", books: { $push: "$title" } } },
{ $out : "authors" }
] )
After the operation, the authors collection contains the following documents:
{ "_id" : "Homer", "books" : [ "The Odyssey", "Iliad" ] }
{ "_id" : "Dante", "books" : [ "The Banquet", "Divine Comedy", "Eclogues" ] }
$project (aggregation)
$project
Passes along the documents with only the specied elds to the next stage in the pipeline. The specied elds
can be existing elds from the input documents or newly computed elds.
The $project (page 466) stage has the following prototype form:
{ $project: { <specifications> } }
466 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $project (page 466) takes a document that can specify the inclusion of elds, the suppression of the
_id eld, the addition of new elds, and the resetting the values of existing elds. The specications have the
following forms:
Syntax Description
<field>: <1 or true> Specify the inclusion of a eld.
_id: <0 or false> Specify the suppression of the _id eld.
<field>: <expression> Add a new eld or reset the value of an existing eld.
Include Existing Fields
The _id eld is, by default, included in the output documents. To include the other elds from the input
documents in the output documents, you must explicitly specify the inclusion in $project (page 466).
If you specify an inclusion of a eld that does not exist in the document, $project (page 466) ignores that
eld inclusion; i.e. $project (page 466) does not add the eld to the document.
Suppress the _id Field The _id eld is always included in the output documents by default. To exclude the
_id eld from the output documents, you must explicitly specify the suppression of the _id eld in $project
(page 466).
Add New Fields or Reset Existing Fields To add a new eld or to reset the value of an existing eld, specify the
eld name and set its value to some expression. For more information on expressions, see Expressions (page 537).
To set a eld value directly to a numeric or boolean literal, as opposed to setting the eld to an expression that resolves
to a literal, use the $literal (page 507) operator. Otherwise, $project (page 466) treats the numeric or boolean
literal as a ag for including or excluding the eld.
By specifying a new eld and setting its value to the eld path of an existing eld, you can effectively rename a eld.
Embedded Document Fields When projecting or adding/resetting a eld within an embedded document, you can
either use dot notation, as in
"contact.address.country": <1 or 0 or expression>
Or you can nest the elds:
contact: { address: { country: <1 or 0 or expression> } }
When nesting the elds, you cannot use dot notation inside the embedded document to specify the eld, e.g.
contact: { "address.country": <1 or 0 or expression> } is invalid.
Examples
Include Specic Fields in Output Documents Consider a books collection with the following document:
{
"_id" : 1,
title: "abc123",
isbn: "0001122223334",
author: { last: "zzz", first: "aaa" },
copies: 5
}
2.3. Operators 467
MongoDB Reference Manual, Release 2.6.4
The following $project (page 466) stage includes only the _id, title, and the author elds in its output
documents:
db.books.aggregate( [ { $project : { title : 1 , author : 1 } } ] )
The operation results in the following document:
{ "_id" : 1, "title" : "abc123", "author" : { "last" : "zzz", "first" : "aaa" } }
Suppress _id Field in the Output Documents The _id eld is always included by default. To exclude the _id
eld from the output documents of the $project (page 466) stage, specify the exclusion of the _id eld by setting
it to 0 in the projection document.
Consider a books collection with the following document:
{
"_id" : 1,
title: "abc123",
isbn: "0001122223334",
author: { last: "zzz", first: "aaa" },
copies: 5
}
The following $project (page 466) stage excludes the _id eld but includes the title, and the author elds
in its output documents:
db.books.aggregate( [ { $project : { _id: 0, title : 1 , author : 1 } } ] )
The operation results in the following document:
{ "title" : "abc123", "author" : { "last" : "zzz", "first" : "aaa" } }
Include Specic Fields from Embedded Documents Consider a bookmarks collection with the following docu-
ments:
{ _id: 1, user: "1234", stop: { title: "book1", author: "xyz", page: 32 } }
{ _id: 2, user: "7890", stop: [ { title: "book2", author: "abc", page: 5 }, { title: "b", author: "ijk", page: 100 } ] }
To include only the title eld in the embedded document in the stop eld, you can use the dot notation:
db.bookmarks.aggregate( [ { $project: { "stop.title": 1 } } ] )
Or, you can nest the inclusion specication in a document:
db.bookmarks.aggregate( [ { $project: { stop: { title: 1 } } } ] )
Both specications result in the following documents:
{ "_id" : 1, "stop" : { "title" : "book1" } }
{ "_id" : 2, "stop" : [ { "title" : "book2" }, { "title" : "book3" } ] }
Include Computed Fields Consider a books collection with the following document:
{
"_id" : 1,
title: "abc123",
isbn: "0001122223334",
author: { last: "zzz", first: "aaa" },
468 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
copies: 5
}
The following $project (page 466) stage adds the new elds isbn, lastName, and copiesSold:
db.books.aggregate(
[
{
$project: {
title: 1,
isbn: {
prefix: { $substr: [ "$isbn", 0, 3 ] },
group: { $substr: [ "$isbn", 3, 2 ] },
publisher: { $substr: [ "$isbn", 5, 4 ] },
title: { $substr: [ "$isbn", 9, 3 ] },
checkDigit: { $substr: [ "$isbn", 12, 1] }
},
lastName: "$author.last",
copiesSold: "$copies"
}
}
]
)
The operation results in the following document:
{
"_id" : 1,
"title" : "abc123",
"isbn" : {
"prefix" : "000",
"group" : "11",
"publisher" : "2222",
"title" : "333",
"checkDigit" : "4"
},
"lastName" : "zzz",
"copiesSold" : 5
}
$redact (aggregation)
Denition
$redact
New in version 2.6.
Restricts the contents of the documents based on information stored in the documents themselves.
The $redact (page 469) stage has the following prototype form:
{ $redact: <expression> }
The argument can be any valid expression (page 537) as long as it resolves to $$DESCEND (page 470),
$$PRUNE (page 470), or $$KEEP (page 470) system variables. For more information on expressions, see
Expressions (page 537).
2.3. Operators 469
MongoDB Reference Manual, Release 2.6.4
Figure 2.2: Diagram of security architecture with middleware and redaction.
System
Variable
Description
$$DE-
SCEND
$redact (page 469) returns the non-subdocument elds at the current
document/subdocument level. For subdocuments or subdocuments in arrays, apply the $cond
(page 518) expression to the subdocuments to determine access for these subdocuments.
$$PRUNE
$redact (page 469) excludes all elds at this current document/subdocument level, without
further inspection of any of the excluded elds. This applies even if the excluded eld
contains subdocuments that may have different access levels.
$$KEEP
$redact (page 469) returns or keeps all elds at this current document/subdocument level,
without further inspection of the elds at this level. This applies even if the included eld
contains subdocuments that may have different access levels.
Examples The examples in this section use the db.collection.aggregate() (page 22) helper provided in
the 2.6 version of the mongo (page 580) shell.
Evaluate Access at Every Document/Sub-document Level A forecasts collection contains documents of the
following form where the tags eld lists the different access values for that document/subdocument level; i.e. a value
of [ "G", "STLW" ] species either "G" or "STLW" can access the data:
{
_id: 1,
title: "123 Department Report",
tags: [ "G", "STLW" ],
year: 2014,
subsections: [
470 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
subtitle: "Section 1: Overview",
tags: [ "SI", "G" ],
content: "Section 1: This is the content of section 1."
},
{
subtitle: "Section 2: Analysis",
tags: [ "STLW" ],
content: "Section 2: This is the content of section 2."
},
{
subtitle: "Section 3: Budgeting",
tags: [ "TK" ],
content: {
text: "Section 3: This is the content of section3.",
tags: [ "HCS" ]
}
}
]
}
A user has access to view information with either the tag "STLW" or "G". To run a query on all documents with year
2014 for this user, include a $redact (page 469) stage as in the following:
var userAccess = [ "STLW", "G" ];
db.forecasts.aggregate(
[
{ $match: { year: 2014 } },
{ $redact:
{
$cond:
{
if: { $gt: [ { $size: { $setIntersection: [ "$tags", userAccess ] } }, 0 ] },
then: "$$DESCEND",
else: "$$PRUNE"
}
}
}
]
)
The aggregation operation returns the following redacted document:
{
"_id" : 1,
"title" : "123 Department Report",
"tags" : [ "G", "STLW" ],
"year" : 2014,
"subsections" : [
{
"subtitle" : "Section 1: Overview",
"tags" : [ "SI", "G" ],
"content" : "Section 1: This is the content of section 1."
},
{
"subtitle" : "Section 2: Analysis",
"tags" : [ "STLW" ],
"content" : "Section 2: This is the content of section 2."
}
2.3. Operators 471
MongoDB Reference Manual, Release 2.6.4
]
}
See also:
$size (page 504), $setIntersection (page 485)
Exclude All Fields at a Given Level A collection accounts contains the following document:
{
_id: 1,
level: 1,
acct_id: "xyz123",
cc: {
level: 5,
type: "yy",
num: 000000000000,
exp_date: ISODate("2015-11-01T00:00:00.000Z"),
billing_addr: {
level: 5,
addr1: "123 ABC Street",
city: "Some City"
},
shipping_addr: [
{
level: 3,
addr1: "987 XYZ Ave",
city: "Some City"
},
{
level: 3,
addr1: "PO Box 0123",
city: "Some City"
}
]
},
status: "A"
}
In this example document, the level eld determines the access level required to view the data.
To run a query on all documents with status A and exclude all elds contained in a document/subdocument at level 5,
include a $redact (page 469) stage that species the system variable "$$PRUNE" in the then eld:
db.accounts.aggregate(
[
{ $match: { status: "A" } },
{ $redact:
{
$cond: {
if: { $eq: [ "$level", 5 ] },
then: "$$PRUNE",
else: "$$DESCEND"
}
}
}
]
)
472 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $redact (page 469) stage evaluates the level eld to determine access. If the level eld equals 5, then
exclude all elds at that level, even if the excluded eld contains subdocuments that may have different level values,
such as the shipping_addr eld.
The aggregation operation returns the following redacted document:
{
"_id" : 1,
"level" : 1,
"acct_id" : "xyz123",
"status" : "A"
}
The result set shows that the $redact (page 469) stage excluded the eld cc as a whole, including the
shipping_addr eld which contained subdocuments that had level eld values equal to 3 and not 5.
See also:
http://docs.mongodb.org/manualtutorial/implement-field-level-redaction for steps to
set up multiple combinations of access for the same data.
$skip (aggregation)
Denition
$skip
Skips over the specied number of documents that pass into the stage and passes the remaining documents to
the next stage in the pipeline.
The $skip (page 473) stage has the following prototype form:
{ $skip: <positive integer> }
$skip (page 473) takes a positive integer that species the maximum number of documents to skip.
Example Consider the following example:
db.article.aggregate(
{ $skip : 5 }
);
This operation skips the rst 5 documents passed to it by the pipeline. $skip (page 473) has no effect on the content
of the documents it passes along the pipeline.
$sort (aggregation)
$sort
Sorts all input documents and returns them to the pipeline in sorted order.
The $sort (page 473) stage has the following prototype form:
{ $sort: { <field1>: <sort order>, <field2>: <sort order> ... } }
$sort (page 473) takes a document that species the eld(s) to sort by and the respective sort order. <sort
order> can have one of the following values:
1 to specify ascending order.
-1 to specify descending order.
2.3. Operators 473
MongoDB Reference Manual, Release 2.6.4
{ $meta: "textScore" } to sort by the computed textScore metadata in descending order.
See Metadata Sort (page 475) for an example.
Examples
Ascending/Descending Sort To ascending order for a eld or elds to sort by and a value of 1 or -1 to specify an
ascending or descending sort respectively, as in the following example:
db.users.aggregate(
[
{ $sort : { age : -1, posts: 1 } }
]
)
This operation sorts the documents in the users collection, in descending order according by the age eld and then
in ascending order according to the value in the posts eld.
When comparing values of different BSON types, MongoDB uses the following comparison order, from lowest to
highest:
1. MinKey (internal type)
2. Null
3. Numbers (ints, longs, doubles)
4. Symbol, String
5. Object
6. Array
7. BinData
8. ObjectId
9. Boolean
10. Date, Timestamp
11. Regular Expression
12. MaxKey (internal type)
MongoDB treats some types as equivalent for comparison purposes. For instance, numeric types undergo conversion
before comparison.
The comparison treats a non-existent eld as it would an empty BSON Object. As such, a sort on the a eld in
documents { } and { a: null } would treat the documents as equivalent in sort order.
With arrays, a less-than comparison or an ascending sort compares the smallest element of arrays, and a greater-than
comparison or a descending sort compares the largest element of the arrays. As such, when comparing a eld whose
value is a single-element array (e.g. [ 1 ]) with non-array elds (e.g. 2), the comparison is between 1 and 2. A
comparison of an empty array (e.g. [ ]) treats the empty array as less than null or a missing eld.
MongoDB sorts BinData in the following order:
1. First, the length or size of the data.
2. Then, by the BSON one-byte subtype.
3. Finally, by the data, performing a byte-by-byte comparison.
474 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Metadata Sort Specify in the { <sort-key> } document, a new eld name for the computed metadata and
specify the $meta (page 503) expression as its value, as in the following example:
db.users.aggregate(
[
{ $match: { $text: { $search: "operating" } } },
{ $sort: { score: { $meta: "textScore" }, posts: -1 } }
]
)
This operation uses the $text (page 401) operator to match the documents, and then sorts rst by the "textScore"
metadata and then by descending order of the posts eld. The specied metadata determines the sort order. For
example, the "textScore" metadata sorts in descending order. See $meta (page 503) for more information on
metadata.
$sort Operator and Memory
$sort + $limit Memory Optimization When a $sort (page 473) immediately precedes a $limit (page 463)
in the pipeline, the $sort (page 473) operation only maintains the top n results as it progresses, where n is
the specied limit, and MongoDB only needs to store n items in memory. This optimization still applies when
allowDiskUse is true and the n items exceed the aggregation memory limit.
Changed in version 2.4: Before MongoDB 2.4, $sort (page 473) would sort all the results in memory, and then limit
the results to n results.
Optimizations are subject to change between releases.
$sort and Memory Restrictions The $sort (page 473) stage has a limit of 100 megabytes of RAM. By default,
if the stage exceeds this limit, $sort (page 473) will produce an error. To allow for the handling of large datasets,
set the allowDiskUse option to true to enable $sort (page 473) operations to write to temporary les. See the
allowDiskUse option in db.collection.aggregate() (page 22) method and the aggregate (page 208)
command for details.
Changed in version 2.6: The memory limit for $sort (page 473) changed from 10 percent of RAM to 100 megabytes
of RAM.
$sort Operator and Performance $sort (page 473) operator can take advantage of an index when placed at the
beginning of the pipeline or placed before the following aggregation operators: $project (page 466), $unwind
(page 475), and $group (page 460).
$unwind (aggregation)
Denition
$unwind
Deconstructs an array eld from the input documents to output a document for each element. Each output
document is the input document with the value of the array eld replaced by the element.
The $unwind (page 475) stage has the following prototype form:
{ $unwind: <field path> }
To specify a eld path, prex the eld name with a dollar sign $ and enclose in quotes.
2.3. Operators 475
MongoDB Reference Manual, Release 2.6.4
Behaviors $unwind (page 475) has the following behaviors:
If a value in the eld specied by the eld path is not an array, db.collection.aggregate() (page 22)
generates an error.
If you specify a path for a eld that does not exist in an input document, the pipeline ignores the input document
and will not output documents for that input document.
If the array holds an empty array ([]) in an input document, the pipeline ignores the input document and will
not output documents for that input document.
Examples Consider an inventory with the following document:
{ "_id" : 1, "item" : "ABC1", sizes: [ "S", "M", "L"] }
The following aggregation uses the $unwind (page 475) stage to output a document for each element in the sizes
array:
db.inventory.aggregate( [ { $unwind : "$sizes" } ] )
The operation returns the following results:
{ "_id" : 1, "item" : "ABC1", "sizes" : "S" }
{ "_id" : 1, "item" : "ABC1", "sizes" : "M" }
{ "_id" : 1, "item" : "ABC1", "sizes" : "L" }
Each document is identical to the input document except for the value of the sizes eld which now holds a value
from the original sizes array.
Expression Operators
These expression operators are available to construct expressions (page 537) for use in the aggregation pipeline.
Operator expressions are similar to functions that take arguments. In general, these expressions take an array of
arguments and have the following form:
{ <operator>: [ <argument1>, <argument2> ... ] }
If operator accepts a single argument, you can omit the outer array designating the argument list:
{ <operator>: <argument> }
To avoid parsing ambiguity if the argument is a literal array, you must wrap the literal array in a $literal (page 507)
expression or keep the outer array that designates the argument list.
Boolean Operators
Boolean expressions evaluates its argument expressions as booleans and return a boolean as the result.
In addition to the false boolean value, Boolean expression evaluates as false the following: null, 0, and
undefined values. The Boolean expression evaluates all other values as true, including non-zero numeric values
and arrays.
476 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Boolean Aggregation Operators Boolean expressions evaluates its argument expressions as booleans and return a
boolean as the result.
In addition to the false boolean value, Boolean expression evaluates as false the following: null, 0, and
undefined values. The Boolean expression evaluates all other values as true, including non-zero numeric values
and arrays.
Name Description
$and
(page 477)
Returns true only when all its expressions evaluate to true. Accepts any number of
argument expressions.
$not
(page 478)
Returns the boolean value that is the opposite of its argument expression. Accepts a single
argument expression.
$or
(page 479)
Returns true when any of its expressions evaluates to true. Accepts any number of argument
expressions.
$and (aggregation)
$and
Evaluates one or more expressions and returns true if all of the expressions are true or if evoked with no
argument expressions. Otherwise, $and (page 477) returns false.
$and (page 477) has the following syntax:
{ $and: [ <expression1>, <expression2>, ... ] }
For more information on expressions, see Expressions (page 537).
Behavior $and (page 477) uses short-circuit logic: the operation stops evaluation after encountering the rst false
expression.
In addition to the false boolean value, $and (page 477) evaluates as false the following: null, 0, and
undefined values. The $and (page 477) evaluates all other values as true, including non-zero numeric values
and arrays.
Example Result
{ $and: [ 1, "green" ] } true
{ $and: [ ] } true
{ $and: [ [ null ], [ false ], [ 0 ] ] } true
{ $and: [ null, true ] } false
{ $and: [ 0, true ] } false
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $and (page 477) operator to determine if qty is greater than 100 and less than 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
2.3. Operators 477
MongoDB Reference Manual, Release 2.6.4
result: { $and: [ { $gt: [ "$qty", 100 ] }, { $lt: [ "$qty", 250 ] } ] }
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "result" : false }
{ "_id" : 2, "item" : "abc2", "result" : true }
{ "_id" : 3, "item" : "xyz1", "result" : false }
{ "_id" : 4, "item" : "VWZ1", "result" : false }
{ "_id" : 5, "item" : "VWZ2", "result" : true }
$not (aggregation)
$not
Evaluates a boolean and returns the opposite boolean value; i.e. when passed an expression that evaluates to
true, $not (page 478) returns false; when passed an expression that evaluates to false, $not (page 478)
returns true.
$not (page 478) has the following syntax:
{ $not: [ <expression> ] }
For more information on expressions, see Expressions (page 537).
Behavior In addition to the false boolean value, $not (page 478) evaluates as false the following: null, 0,
and undefined values. The $not (page 478) evaluates all other values as true, including non-zero numeric values
and arrays.
Example Result
{ $not: [ true ] } false
{ $not: [ [ false ] ] } false
{ $not: [ false ] } true
{ $not: [ null ] } true
{ $not: [ 0 ] } true
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $or (page 479) operator to determine if qty is greater than 250 or less than 200:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
result: { $not: [ { $gt: [ "$qty", 250 ] } ] }
}
}
478 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "result" : false }
{ "_id" : 2, "item" : "abc2", "result" : true }
{ "_id" : 3, "item" : "xyz1", "result" : true }
{ "_id" : 4, "item" : "VWZ1", "result" : false }
{ "_id" : 5, "item" : "VWZ2", "result" : true }
$or (aggregation)
$or
Evaluates one or more expressions and returns true if any of the expressions are true. Otherwise, $or
(page 479) returns false.
$or (page 479) has the following syntax:
{ $or: [ <expression1>, <expression2>, ... ] }
For more information on expressions, see Expressions (page 537).
Behavior $or (page 479) uses short-circuit logic: the operation stops evaluation after encountering the rst true
expression.
In addition to the false boolean value, $or (page 479) evaluates as false the following: null, 0, and
undefined values. The $or (page 479) evaluates all other values as true, including non-zero numeric values
and arrays.
Example Result
{ $or: [ true, false ] } true
{ $or: [ [ false ], false ] } true
{ $or: [ null, 0, undefined ] } false
{ $or: [ ] } false
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $or (page 479) operator to determine if qty is greater than 250 or less than 200:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
result: { $or: [ { $gt: [ "$qty", 250 ] }, { $lt: [ "$qty", 200 ] } ] }
}
}
]
)
2.3. Operators 479
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "result" : true }
{ "_id" : 2, "item" : "abc2", "result" : false }
{ "_id" : 3, "item" : "xyz1", "result" : false }
{ "_id" : 4, "item" : "VWZ1", "result" : true }
{ "_id" : 5, "item" : "VWZ2", "result" : true }
Set Operators
Set expressions performs set operation on arrays, treating arrays as sets. Set expressions ignores the duplicate entries
in each input array and the order of the elements.
If the set operation returns a set, the operation lters out duplicates in the result to output an array that contains only
unique entries. The order of the elements in the output array is unspecied.
If a set contains a nested array element, the set expression does not descend into the nested array but evaluates the
array at top-level.
Set Operators (Aggregation) Set expressions performs set operation on arrays, treating arrays as sets. Set expres-
sions ignores the duplicate entries in each input array and the order of the elements.
If the set operation returns a set, the operation lters out duplicates in the result to output an array that contains only
unique entries. The order of the elements in the output array is unspecied.
If a set contains a nested array element, the set expression does not descend into the nested array but evaluates the
array at top-level.
Name Description
$allElementsTrue
(page 480)
Returns true if no element of a set evaluates to false, otherwise, returns false.
Accepts a single argument expression.
$anyElementTrue
(page 482)
Returns true if any elements of a set evaluate to true; otherwise, returns false.
Accepts a single argument expression.
$setDifference
(page 483)
Returns a set with elements that appear in the rst set but not in the second set; i.e. performs
a relative complement
29
of the second set relative to the rst. Accepts exactly two argument
expressions.
$setEquals
(page 484)
Returns true if the input sets have the same distinct elements. Accepts two or more
argument expressions.
$setIntersection
(page 485)
Returns a set with elements that appear in all of the input sets. Accepts any number of
argument expressions.
$setIsSubset
(page 486)
Returns true if all elements of the rst set appear in the second set, including when the
rst set equals the second set; i.e. not a strict subset
30
. Accepts exactly two argument
expressions.
$setUnion
(page 487)
Returns a set with elements that appear in any of the input sets. Accepts any number of
argument expressions.
$allElementsTrue (aggregation)
$allElementsTrue
New in version 2.6.
27
http://en.wikipedia.org/wiki/Complement_(set_theory)
28
http://en.wikipedia.org/wiki/Subset
29
http://en.wikipedia.org/wiki/Complement_(set_theory)
30
http://en.wikipedia.org/wiki/Subset
480 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Evaluates an array as a set and returns true if no element in the array is false. Otherwise, returns false.
An empty array returns true.
$allElementsTrue (page 480) has the following syntax:
{ $allElementsTrue: [ <expression> ] }
The <expression> itself must resolve to an array, separate from the outer array that denotes the argument
list. For more information on expressions, see Expressions (page 537).
Behavior If a set contains a nested array element, $allElementsTrue (page 480) does not descend into the
nested array but evaluates the array at top-level.
In addition to the false boolean value, $allElementsTrue (page 480) evaluates as false the following: null,
0, and undefined values. The $allElementsTrue (page 480) evaluates all other values as true, including
non-zero numeric values and arrays.
Example Result
{ $allElementsTrue: [ [ true, 1, "someString" ] ] } true
{ $allElementsTrue: [ [ [ false ] ] ] } true
{ $allElementsTrue: [ [ ] ] } true
{ $allElementsTrue: [ [ null, false, 0 ] ] } false
Example Consider an survey collection with the following documents:
{ "_id" : 1, "responses" : [ true ] }
{ "_id" : 2, "responses" : [ true, false ] }
{ "_id" : 3, "responses" : [ ] }
{ "_id" : 4, "responses" : [ 1, true, "seven" ] }
{ "_id" : 5, "responses" : [ 0 ] }
{ "_id" : 6, "responses" : [ [ ] ] }
{ "_id" : 7, "responses" : [ [ 0 ] ] }
{ "_id" : 8, "responses" : [ [ false ] ] }
{ "_id" : 9, "responses" : [ null ] }
{ "_id" : 10, "responses" : [ undefined ] }
The following operation uses the $allElementsTrue (page 480) operator to determine if the responses array
only contains values that evaluate to true:
db.survey.aggregate(
[
{ $project: { responses: 1, isAllTrue: { $allElementsTrue: [ "$responses" ] }, _id: 0 } }
]
)
The operation returns the following results:
{ "responses" : [ true ], "isAllTrue" : true }
{ "responses" : [ true, false ], "isAllTrue" : false }
{ "responses" : [ ], "isAllTrue" : true }
{ "responses" : [ 1, true, "seven" ], "isAllTrue" : true }
{ "responses" : [ 0 ], "isAllTrue" : false }
{ "responses" : [ [ ] ], "isAllTrue" : true }
{ "responses" : [ [ 0 ] ], "isAllTrue" : true }
{ "responses" : [ [ false ] ], "isAllTrue" : true }
{ "responses" : [ null ], "isAllTrue" : false }
{ "responses" : [ null ], "isAllTrue" : false }
2.3. Operators 481
MongoDB Reference Manual, Release 2.6.4
$anyElementTrue (aggregation)
$anyElementTrue
New in version 2.6.
Evaluates an array as a set and returns true if any of the elements are true and false otherwise. An empty
array returns false.
$anyElementTrue (page 482) has the following syntax:
{ $anyElementTrue: [ <expression> ] }
The <expression> itself must resolve to an array, separate from the outer array that denotes the argument
list. For more information on expressions, see Expressions (page 537).
Behavior If a set contains a nested array element, $anyElementTrue (page 482) does not descend into the nested
array but evaluates the array at top-level.
In addition to the false boolean value, $anyElementTrue (page 482) evaluates as false the following: null,
0, and undefined values. The $anyElementTrue (page 482) evaluates all other values as true, including
non-zero numeric values and arrays.
Example Result
{ $anyElementTrue: [ [ true, false ] ] } true
{ $anyElementTrue: [ [ [ false ] ] ] } true
{ $anyElementTrue: [ [ null, false, 0 ] ] } false
{ $anyElementTrue: [ [ ] ] } false
Example Consider an survey collection with the following documents:
{ "_id" : 1, "responses" : [ true ] }
{ "_id" : 2, "responses" : [ true, false ] }
{ "_id" : 3, "responses" : [ ] }
{ "_id" : 4, "responses" : [ 1, true, "seven" ] }
{ "_id" : 5, "responses" : [ 0 ] }
{ "_id" : 6, "responses" : [ [ ] ] }
{ "_id" : 7, "responses" : [ [ 0 ] ] }
{ "_id" : 8, "responses" : [ [ false ] ] }
{ "_id" : 9, "responses" : [ null ] }
{ "_id" : 10, "responses" : [ undefined ] }
The following operation uses the $anyElementTrue (page 482) operator to determine if the responses array
contains any value that evaluates to true:
db.survey.aggregate(
[
{ $project: { responses: 1, isAnyTrue: { $anyElementTrue: [ "$responses" ] }, _id: 0 } }
]
)
The operation returns the following results:
{ "responses" : [ true ], "isAnyTrue" : true }
{ "responses" : [ true, false ], "isAnyTrue" : true }
{ "responses" : [ ], "isAnyTrue" : false }
{ "responses" : [ 1, true, "seven" ], "isAnyTrue" : true }
{ "responses" : [ 0 ], "isAnyTrue" : false }
{ "responses" : [ [ ] ], "isAnyTrue" : true }
{ "responses" : [ [ 0 ] ], "isAnyTrue" : true }
482 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "responses" : [ [ false ] ], "isAnyTrue" : true }
{ "responses" : [ null ], "isAnyTrue" : false }
{ "responses" : [ null ], "isAnyTrue" : false }
$setDifference (aggregation)
$setDifference
New in version 2.6.
Takes two sets and returns an array containing the elements that only exist in the rst set; i.e. performs a relative
complement
31
of the second set relative to the rst.
$setDifference (page 483) has the following syntax:
{ $setDifference: [ <expression1>, <expression2> ] }
The arguments can be any valid expression (page 537) as long as they each resolve to an array. For more
information on expressions, see Expressions (page 537).
Behavior $setDifference (page 483) performs set operation on arrays, treating arrays as sets. If an array con-
tains duplicate entries, $setDifference (page 483) ignores the duplicate entries. $setDifference (page 483)
ignores the order of the elements.
$setDifference (page 483) lters out duplicates in its result to output an array that contain only unique entries.
The order of the elements in the output array is unspecied.
If a set contains a nested array element, $setDifference (page 483) does not descend into the nested array but
evaluates the array at top-level.
Example Result
{ $setDifference: [ [ "a", "b", "a" ], [ "b", "a" ] ] } [ ]
{ $setDifference: [ [ "a", "b" ], [ [ "a", "b" ] ] ] } [ "a", "b" ]
Example Consider an experiments collection with the following documents:
{ "_id" : 1, "A" : [ "red", "blue" ], "B" : [ "red", "blue" ] }
{ "_id" : 2, "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ] }
{ "_id" : 3, "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ] }
{ "_id" : 4, "A" : [ "red", "blue" ], "B" : [ "green", "red" ] }
{ "_id" : 5, "A" : [ "red", "blue" ], "B" : [ ] }
{ "_id" : 6, "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ] }
{ "_id" : 7, "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ] }
{ "_id" : 8, "A" : [ ], "B" : [ ] }
{ "_id" : 9, "A" : [ ], "B" : [ "red" ] }
The following operation uses the $setDifference (page 483) operator to return an array of elements found in the
B array but not in the A array:
db.experiments.aggregate(
[
{ $project: { A: 1, B: 1, inBOnly: { $setDifference: [ "$B", "$A" ] }, _id: 0 } }
]
)
The operation returns the following results:
31
http://en.wikipedia.org/wiki/Complement_(set_theory)
2.3. Operators 483
MongoDB Reference Manual, Release 2.6.4
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue" ], "inBOnly" : [ ] }
{ "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ], "inBOnly" : [ ] }
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ], "inBOnly" : [ "green" ] }
{ "A" : [ "red", "blue" ], "B" : [ "green", "red" ], "inBOnly" : [ "green" ] }
{ "A" : [ "red", "blue" ], "B" : [ ], "inBOnly" : [ ] }
{ "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ], "inBOnly" : [ [ "red" ], [ "blue" ] ] }
{ "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ], "inBOnly" : [ [ "red", "blue" ] ] }
{ "A" : [ ], "B" : [ ], "inBOnly" : [ ] }
{ "A" : [ ], "B" : [ "red" ], "inBOnly" : [ "red" ] }
$setEquals (aggregation)
$setEquals
New in version 2.6.
Compares two or more arrays and returns true if they have the same distinct elements and false otherwise.
$setEquals (page 484) has the following syntax:
{ $setEquals: [ <expression1>, <expression2>, ... ] }
The arguments can be any valid expression (page 537) as long as they each resolve to an array. For more
information on expressions, see Expressions (page 537).
Behavior $setEquals (page 484) performs set operation on arrays, treating arrays as sets. If an array contains
duplicate entries, $setEquals (page 484) ignores the duplicate entries. $setEquals (page 484) ignores the order
of the elements.
If a set contains a nested array element, $setEquals (page 484) does not descend into the nested array but evaluates
the array at top-level.
Example Result
{ $setEquals: [ [ "a", "b", "a" ], [ "b", "a" ] ] } true
{ $setEquals: [ [ "a", "b" ], [ [ "a", "b" ] ] ] } false
Example Consider an experiments collection with the following documents:
{ "_id" : 1, "A" : [ "red", "blue" ], "B" : [ "red", "blue" ] }
{ "_id" : 2, "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ] }
{ "_id" : 3, "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ] }
{ "_id" : 4, "A" : [ "red", "blue" ], "B" : [ "green", "red" ] }
{ "_id" : 5, "A" : [ "red", "blue" ], "B" : [ ] }
{ "_id" : 6, "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ] }
{ "_id" : 7, "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ] }
{ "_id" : 8, "A" : [ ], "B" : [ ] }
{ "_id" : 9, "A" : [ ], "B" : [ "red" ] }
The following operation uses the $setEquals (page 484) operator to determine if the A array and the B array contain
the same elements:
db.experiments.aggregate(
[
{ $project: { A: 1, B: 1, sameElements: { $setEquals: [ "$A", "$B" ] }, _id: 0 } }
]
)
The operation returns the following results:
484 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue" ], "sameElements" : true }
{ "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ], "sameElements" : true }
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ], "sameElements" : false }
{ "A" : [ "red", "blue" ], "B" : [ "green", "red" ], "sameElements" : false }
{ "A" : [ "red", "blue" ], "B" : [ ], "sameElements" : false }
{ "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ], "sameElements" : false }
{ "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ], "sameElements" : false }
{ "A" : [ ], "B" : [ ], "sameElements" : true }
{ "A" : [ ], "B" : [ "red" ], "sameElements" : false }
$setIntersection (aggregation)
$setIntersection
New in version 2.6.
Takes two or more arrays and returns an array that contains the elements that appear in every input array.
$setIntersection (page 485) has the following syntax:
{ $setIntersection: [ <array1>, <array2>, ... ] }
The arguments can be any valid expression (page 537) as long as they each resolve to an array. For more
information on expressions, see Expressions (page 537).
Behavior $setIntersection (page 485) performs set operation on arrays, treating arrays as sets. If an array
contains duplicate entries, $setIntersection (page 485) ignores the duplicate entries. $setIntersection
(page 485) ignores the order of the elements.
$setIntersection (page 485) lters out duplicates in its result to output an array that contain only unique entries.
The order of the elements in the output array is unspecied.
If a set contains a nested array element, $setIntersection (page 485) does not descend into the nested array but
evaluates the array at top-level.
Example Result
{ $setIntersection: [ [ "a", "b", "a" ], [ "b", "a" ] ] } [ "b", "a" ]
{ $setIntersection: [ [ "a", "b" ], [ [ "a", "b" ] ] ] } [ ]
Example Consider an experiments collection with the following documents:
{ "_id" : 1, "A" : [ "red", "blue" ], "B" : [ "red", "blue" ] }
{ "_id" : 2, "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ] }
{ "_id" : 3, "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ] }
{ "_id" : 4, "A" : [ "red", "blue" ], "B" : [ "green", "red" ] }
{ "_id" : 5, "A" : [ "red", "blue" ], "B" : [ ] }
{ "_id" : 6, "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ] }
{ "_id" : 7, "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ] }
{ "_id" : 8, "A" : [ ], "B" : [ ] }
{ "_id" : 9, "A" : [ ], "B" : [ "red" ] }
The following operation uses the $setIntersection (page 485) operator to return an array of elements common
to both the A array and the B array:
db.experiments.aggregate(
[
{ $project: { A: 1, B: 1, commonToBoth: { $setIntersection: [ "$A", "$B" ] }, _id: 0 } }
]
)
2.3. Operators 485
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue" ], "commonToBoth" : [ "blue", "red" ] }
{ "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ], "commonToBoth" : [ "blue", "red" ] }
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ], "commonToBoth" : [ "blue", "red" ] }
{ "A" : [ "red", "blue" ], "B" : [ "green", "red" ], "commonToBoth" : [ "red" ] }
{ "A" : [ "red", "blue" ], "B" : [ ], "commonToBoth" : [ ] }
{ "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ], "commonToBoth" : [ ] }
{ "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ], "commonToBoth" : [ ] }
{ "A" : [ ], "B" : [ ], "commonToBoth" : [ ] }
{ "A" : [ ], "B" : [ "red" ], "commonToBoth" : [ ] }
$setIsSubset (aggregation)
$setIsSubset
New in version 2.6.
Takes two arrays and returns true when the rst array is a subset of the second, including when the rst array
equals the second array, and false otherwise.
$setIsSubset (page 486) has the following syntax:
{ $setIsSubset: [ <expression1>, <expression2> ] }
The arguments can be any valid expression (page 537) as long as they each resolve to an array. For more
information on expressions, see Expressions (page 537).
Behavior $setIsSubset (page 486) performs set operation on arrays, treating arrays as sets. If an array contains
duplicate entries, $setIsSubset (page 486) ignores the duplicate entries. $setIsSubset (page 486) ignores the
order of the elements.
If a set contains a nested array element, $setIsSubset (page 486) does not descend into the nested array but
evaluates the array at top-level.
Example Result
{ $setIsSubset: [ [ "a", "b", "a" ], [ "b", "a" ] ] } true
{ $setIsSubset: [ [ "a", "b" ], [ [ "a", "b" ] ] ] } false
Example Consider an experiments collection with the following documents:
{ "_id" : 1, "A" : [ "red", "blue" ], "B" : [ "red", "blue" ] }
{ "_id" : 2, "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ] }
{ "_id" : 3, "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ] }
{ "_id" : 4, "A" : [ "red", "blue" ], "B" : [ "green", "red" ] }
{ "_id" : 5, "A" : [ "red", "blue" ], "B" : [ ] }
{ "_id" : 6, "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ] }
{ "_id" : 7, "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ] }
{ "_id" : 8, "A" : [ ], "B" : [ ] }
{ "_id" : 9, "A" : [ ], "B" : [ "red" ] }
The following operation uses the $setIsSubset (page 486) operator to determine if the A array is a subset of the B
array:
db.experiments.aggregate(
[
{ $project: { A:1, B: 1, AisSubset: { $setIsSubset: [ "$A", "$B" ] }, _id:0 } }
]
)
486 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue" ], "AisSubset" : true }
{ "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ], "AisSubset" : true }
{ "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ], "AisSubset" : true }
{ "A" : [ "red", "blue" ], "B" : [ "green", "red" ], "AisSubset" : false }
{ "A" : [ "red", "blue" ], "B" : [ ], "AisSubset" : false }
{ "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ], "AisSubset" : false }
{ "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ], "AisSubset" : false }
{ "A" : [ ], "B" : [ ], "AisSubset" : true }
{ "A" : [ ], "B" : [ "red" ], "AisSubset" : true }
$setUnion (aggregation)
$setUnion
New in version 2.6.
Takes two or more arrays and returns an array containing the elements that appear in any input array.
$setUnion (page 487) has the following syntax:
{ $setUnion: [ <expression1>, <expression2>, ... ] }
The arguments can be any valid expression (page 537) as long as they each resolve to an array. For more
information on expressions, see Expressions (page 537).
Behavior $setUnion (page 487) performs set operation on arrays, treating arrays as sets. If an array contains
duplicate entries, $setUnion (page 487) ignores the duplicate entries. $setUnion (page 487) ignores the order of
the elements.
$setUnion (page 487) lters out duplicates in its result to output an array that contain only unique entries. The
order of the elements in the output array is unspecied.
If a set contains a nested array element, $setUnion (page 487) does not descend into the nested array but evaluates
the array at top-level.
Example Result
{ $setUnion: [ [ "a", "b", "a" ], [ "b", "a" ]
] }
[ "b", "a" ]
{ $setUnion: [ [ "a", "b" ], [ [ "a", "b" ] ]
] }
[ [ "a", "b" ], "b", "a"
]
Example Consider an experiments collection with the following documents:
{ "_id" : 1, "A" : [ "red", "blue" ], "B" : [ "red", "blue" ] }
{ "_id" : 2, "A" : [ "red", "blue" ], "B" : [ "blue", "red", "blue" ] }
{ "_id" : 3, "A" : [ "red", "blue" ], "B" : [ "red", "blue", "green" ] }
{ "_id" : 4, "A" : [ "red", "blue" ], "B" : [ "green", "red" ] }
{ "_id" : 5, "A" : [ "red", "blue" ], "B" : [ ] }
{ "_id" : 6, "A" : [ "red", "blue" ], "B" : [ [ "red" ], [ "blue" ] ] }
{ "_id" : 7, "A" : [ "red", "blue" ], "B" : [ [ "red", "blue" ] ] }
{ "_id" : 8, "A" : [ ], "B" : [ ] }
{ "_id" : 9, "A" : [ ], "B" : [ "red" ] }
The following operation uses the $setUnion (page 487) operator to return an array of elements found in the A array
or the B array or both:
2.3. Operators 487
MongoDB Reference Manual, Release 2.6.4
db.experiments.aggregate(
[
{ $project: { A:1, B: 1, allValues: { $setUnion: [ "$A", "$B" ] }, _id: 0 } }
]
)
The operation returns the following results:
{ "A": [ "red", "blue" ], "B": [ "red", "blue" ], "allValues": [ "blue", "red" ] }
{ "A": [ "red", "blue" ], "B": [ "blue", "red", "blue" ], "allValues": [ "blue", "red" ] }
{ "A": [ "red", "blue" ], "B": [ "red", "blue", "green" ], "allValues": [ "blue", "red", "green" ] }
{ "A": [ "red", "blue" ], "B": [ "green", "red" ], "allValues": [ "blue", "red", "green" ] }
{ "A": [ "red", "blue" ], "B": [ ], "allValues": [ "blue", "red" ] }
{ "A": [ "red", "blue" ], "B": [ [ "red" ], [ "blue" ] ], "allValues": [ "blue", "red", [ "red" ], [ "blue" ] ] }
{ "A": [ "red", "blue" ], "B": [ [ "red", "blue" ] ], "allValues": [ "blue", "red", [ "red", "blue" ] ] }
{ "A": [ ], "B": [ ], "allValues": [ ] }
{ "A": [ ], "B": [ "red" ], "allValues": [ "red" ] }
Comparison Operators
Comparison expressions return a boolean except for $cmp (page 488) which returns a number.
The comparison expressions take two argument expressions and compare both value and type, using the specied
BSON comparison order for values of different types.
Comparison Aggregation Operators Comparison expressions return a boolean except for $cmp (page 488) which
returns a number.
The comparison expressions take two argument expressions and compare both value and type, using the specied
BSON comparison order for values of different types.
Name Description
$cmp
(page 488)
Returns: 0 if the two values are equivalent, 1 if the rst value is greater than the second, and -1 if
the rst value is less than the second.
$eq
(page 489)
Returns true if the values are equivalent.
$gt
(page 490)
Returns true if the rst value is greater than the second.
$gte
(page 491)
Returns true if the rst value is greater than or equal to the second.
$lt
(page 492)
Returns true if the rst value is less than the second.
$lte
(page 493)
Returns true if the rst value is less than or equal to the second.
$ne
(page 493)
Returns true if the values are not equivalent.
$cmp (aggregation)
$cmp
Compares two values and returns:
-1 if the rst value is less than the second.
1 if the rst value is greater than the second.
0 if the two values are equivalent.
488 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $cmp (page 488) compares both value and type, using the specied BSON comparison order for values of
different types.
$cmp (page 488) has the following syntax:
{ $cmp: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $cmp (page 488) operator to compare the qty value with 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
cmpTo250: { $cmp: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "cmpTo250" : 1 }
{ "item" : "abc2", "qty" : 200, "cmpTo250" : -1 }
{ "item" : "xyz1", "qty" : 250, "cmpTo250" : 0 }
{ "item" : "VWZ1", "qty" : 300, "cmpTo250" : 1 }
{ "item" : "VWZ2", "qty" : 180, "cmpTo250" : -1 }
$eq (aggregation)
$eq
Compares two values and returns:
true when the values are equivalent.
false when the values are not equivalent.
The $eq (page 489) compares both value and type, using the specied BSON comparison order for values of
different types.
$eq (page 489) has the following syntax:
{ $eq: [ <expression1>, <expression2> ] }
The arguments can be any valid expression (page 537). For more information on expressions, see Expressions
(page 537).
2.3. Operators 489
MongoDB Reference Manual, Release 2.6.4
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $eq (page 489) operator to determine if qty equals 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyEq250: { $eq: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyEq250" : false }
{ "item" : "abc2", "qty" : 200, "qtyEq250" : false }
{ "item" : "xyz1", "qty" : 250, "qtyEq250" : true }
{ "item" : "VWZ1", "qty" : 300, "qtyEq250" : false }
{ "item" : "VWZ2", "qty" : 180, "qtyEq250" : false }
$gt (aggregation)
$gt
Compares two values and returns:
true when the rst value is greater than the second value.
false when the rst value is less than or equivalent to the second value.
The $gt (page 490) compares both value and type, using the specied BSON comparison order for values of
different types.
$gt (page 490) has the following syntax:
{ $gt: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $gt (page 490) operator to determine if qty is greater than 250:
490 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyGt250: { $gt: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyGt250" : true }
{ "item" : "abc2", "qty" : 200, "qtyGt250" : false }
{ "item" : "xyz1", "qty" : 250, "qtyGt250" : false }
{ "item" : "VWZ1", "qty" : 300, "qtyGt250" : true }
{ "item" : "VWZ2", "qty" : 180, "qtyGt250" : false }
$gte (aggregation)
$gte
Compares two values and returns:
true when the rst value is greater than or equivalent to the second value.
false when the rst value is less than the second value.
The $gte (page 491) compares both value and type, using the specied BSON comparison order for values of
different types.
$gte (page 491) has the following syntax:
{ $gte: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $gte (page 491) operator to determine if qty is greater than or equal to 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyGte250: { $gte: [ "$qty", 250 ] },
_id: 0
2.3. Operators 491
MongoDB Reference Manual, Release 2.6.4
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyGte250" : true }
{ "item" : "abc2", "qty" : 200, "qtyGte250" : false }
{ "item" : "xyz1", "qty" : 250, "qtyGte250" : true }
{ "item" : "VWZ1", "qty" : 300, "qtyGte250" : true }
{ "item" : "VWZ2", "qty" : 180, "qtyGte250" : false }
$lt (aggregation)
$lt
Compares two values and returns:
true when the rst value is less than the second value.
false when the rst value is greater than or equivalent to the second value.
The $lt (page 492) compares both value and type, using the specied BSON comparison order for values of
different types.
$lt (page 492) has the following syntax:
{ $lt: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $lt (page 492) operator to determine if qty is less than 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyLt250: { $lt: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyLt250" : false }
{ "item" : "abc2", "qty" : 200, "qtyLt250" : true }
{ "item" : "xyz1", "qty" : 250, "qtyLt250" : false }
492 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "item" : "VWZ1", "qty" : 300, "qtyLt250" : false }
{ "item" : "VWZ2", "qty" : 180, "qtyLt250" : true }
$lte (aggregation)
$lte
Compares two values and returns:
true when the rst value is less than or equivalent to the second value.
false when the rst value is greater than the second value.
The $lte (page 493) compares both value and type, using the specied BSON comparison order for values of
different types.
$lte (page 493) has the following syntax:
{ $lte: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $lte (page 493) operator to determine if qty is less than or equal to 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyLte250: { $lte: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyLte250" : false }
{ "item" : "abc2", "qty" : 200, "qtyLte250" : true }
{ "item" : "xyz1", "qty" : 250, "qtyLte250" : true }
{ "item" : "VWZ1", "qty" : 300, "qtyLte250" : false }
{ "item" : "VWZ2", "qty" : 180, "qtyLte250" : true }
$ne (aggregation)
$ne
Compares two values and returns:
true when the values are not equivalent.
2.3. Operators 493
MongoDB Reference Manual, Release 2.6.4
false when the values are equivalent.
The $lte (page 493) compares both value and type, using the specied BSON comparison order for values of
different types.
$ne (page 493) has the following syntax:
{ $ne: [ <expression1>, <expression2> ] }
For more information on expressions, see Expressions (page 537).
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: "product 2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", description: "product 3", qty: 250 }
{ "_id" : 4, "item" : "VWZ1", description: "product 4", qty: 300 }
{ "_id" : 5, "item" : "VWZ2", description: "product 5", qty: 180 }
The following operation uses the $ne (page 493) operator to determine if qty does not equal 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
qty: 1,
qtyNe250: { $ne: [ "$qty", 250 ] },
_id: 0
}
}
]
)
The operation returns the following results:
{ "item" : "abc1", "qty" : 300, "qtyNe250" : true }
{ "item" : "abc2", "qty" : 200, "qtyNe250" : true }
{ "item" : "xyz1", "qty" : 250, "qtyNe250" : false }
{ "item" : "VWZ1", "qty" : 300, "qtyNe250" : true }
{ "item" : "VWZ2", "qty" : 180, "qtyNe250" : true }
Arithmetic Operators
Arithmetic expressions perform mathematic operations on numbers. Some arithmetic expressions can also support
date arithmetic.
Arithmetic Aggregation Operators Arithmetic expressions perform mathematic operations on numbers. Some
arithmetic expressions can also support date arithmetic.
494 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Name Description
$add
(page 495)
Adds numbers to return the sum, or adds numbers and a date to return a new date. If adding
numbers and a date, treats the numbers as milliseconds. Accepts any number of argument
expressions, but at most, one expression can resolve to a date.
$divide
(page 496)
Returns the result of dividing the rst number by the second. Accepts two argument expressions.
$mod
(page 496)
Returns the remainder of the rst number divided by the second. Accepts two argument
expressions.
$multiply
(page 497)
Multiplies numbers to return the product. Accepts any number of argument expressions.
$subtract
(page 497)
Returns the result of subtracting the second value from the rst. If the two values are numbers,
return the difference. If the two values are dates, return the difference in milliseconds. If the two
values are a date and a number in milliseconds, return the resulting date. Accepts two argument
expressions. If the two values are a date and a number, specify the date argument rst as it is not
meaningful to subtract a date from a number.
$add (aggregation)
$add
Adds numbers together or adds numbers and a date. If one of the arguments is a date, $add (page 495) treats
the other arguments as milliseconds to add to the date.
The $add (page 495) expression has the following syntax:
{ $add: [ <expression1>, <expression2>, ... ] }
The arguments can be any valid expression (page 537) as long as they resolve to either all numbers or to numbers
and a date. For more information on expressions, see Expressions (page 537).
Examples The following examples use a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "fee" : 2, date: ISODate("2014-03-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "fee" : 1, date: ISODate("2014-03-01T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "fee" : 0, date: ISODate("2014-03-15T09:00:00Z") }
Add Numbers The following aggregation uses the $add (page 495) expression in the $project (page 466)
pipeline to calculate the total cost:
db.sales.aggregate(
[
{ $project: { item: 1, total: { $add: [ "$price", "$fee" ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "total" : 12 }
{ "_id" : 2, "item" : "jkl", "total" : 21 }
{ "_id" : 3, "item" : "xyz", "total" : 5 }
Perform Addition on a Date The following aggregation uses the $add (page 495) expression to compute the
billing_date by adding 3
*
24
*
60
*
60000 milliseconds (i.e. 3 days) to the date eld :
2.3. Operators 495
MongoDB Reference Manual, Release 2.6.4
db.sales.aggregate(
[
{ $project: { item: 1, billing_date: { $add: [ "$date", 3
*
24
*
60
*
60000 ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "billing_date" : ISODate("2014-03-04T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "billing_date" : ISODate("2014-03-04T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "billing_date" : ISODate("2014-03-18T09:00:00Z") }
$divide (aggregation)
$divide
Divides one number by another and returns the result. Pass the arguments to $divide (page 496) in an array.
The $divide (page 496) expression has the following syntax:
{ $divide: [ <expression1>, <expression2> ] }
The rst argument is the dividend, and the second argument is the divisor; i.e. the rst argument is divided by
the second argument.
The arguments can be any valid expression (page 537) as long as the resolve to numbers. For more information
on expressions, see Expressions (page 537).
Examples Consider a planning collection with the following documents:
{ "_id" : 1, "name" : "A", "hours" : 80, "resources" : 7 },
{ "_id" : 2, "name" : "B", "hours" : 40, "resources" : 4 }
The following aggregation uses the $divide (page 496) expression to divide the hours eld by a literal 8 to
compute the number of work days:
db.planning.aggregate(
[
{ $project: { name: 1, workdays: { $divide: [ "$hours", 8 ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "name" : "A", "workdays" : 10 }
{ "_id" : 2, "name" : "B", "workdays" : 5 }
$mod (aggregation)
$mod
Divides one number by another and returns the remainder.
The $mod (page 496) expression has the following syntax:
{ $mod: [ <expression1>, <expression2> ] }
The rst argument is the dividend, and the second argument is the divisor; i.e. rst argument is divided by the
second argument.
The arguments can be any valid expression (page 537) as long as they resolve to numbers. For more information
on expressions, see Expressions (page 537).
496 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Example Consider a planning collection with the following documents:
{ "_id" : 1, "project" : "A", "hours" : 80, "tasks" : 7 }
{ "_id" : 2, "project" : "B", "hours" : 40, "tasks" : 4 }
The following aggregation uses the $mod (page 496) expression to return the remainder of the hours eld divided
by the tasks eld:
db.planning.aggregate(
[
{ $project: { remainder: { $mod: [ "$hours", "$tasks" ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "remainder" : 3 }
{ "_id" : 2, "remainder" : 0 }
$multiply (aggregation)
$multiply
Multiplies numbers together and returns the result. Pass the arguments to $multiply (page 497) in an array.
The $multiply (page 497) expression has the following syntax:
{ $multiply: [ <expression1>, <expression2>, ... ] }
The arguments can be any valid expression (page 537) as long as they resolve to numbers. For more information
on expressions, see Expressions (page 537).
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity": 2, date: ISODate("2014-03-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity": 1, date: ISODate("2014-03-01T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity": 10, date: ISODate("2014-03-15T09:00:00Z") }
The following aggregation uses the $multiply (page 497) expression in the $project (page 466) pipeline to
multiply the price and the quantity elds:
db.sales.aggregate(
[
{ $project: { date: 1, item: 1, total: { $multiply: [ "$price", "$quantity" ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "date" : ISODate("2014-03-01T08:00:00Z"), "total" : 20 }
{ "_id" : 2, "item" : "jkl", "date" : ISODate("2014-03-01T09:00:00Z"), "total" : 20 }
{ "_id" : 3, "item" : "xyz", "date" : ISODate("2014-03-15T09:00:00Z"), "total" : 50 }
$subtract (aggregation)
$subtract
Subtracts two numbers to return the difference, or two dates to return the difference in milliseconds, or a date
and a number in milliseconds to return the resulting date.
The $subtract (page 497) expression has the following syntax:
2.3. Operators 497
MongoDB Reference Manual, Release 2.6.4
{ $subtract: [ <expression1>, <expression2> ] }
The second argument is subtracted from the rst argument.
The arguments can be any valid expression (page 537) as long as they resolve to numbers and/or dates. To
subtract a number from a date, the date must be the rst argument. For more information on expressions, see
Expressions (page 537).
Examples Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "fee" : 2, "discount" : 5, "date" : ISODate("2014-03-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "fee" : 1, "discount" : 2, "date" : ISODate("2014-03-01T09:00:00Z") }
Subtract Numbers The following aggregation uses the $subtract (page 497) expression to compute the total
by subtracting the discount from the subtotal of price and fee.
db.sales.aggregate( [ { $project: { item: 1, total: { $subtract: [ { $add: [ "$price", "$fee" ] }, "$discount" ] } } } ] )
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "total" : 7 }
{ "_id" : 2, "item" : "jkl", "total" : 19 }
Subtract Two Dates The following aggregation uses the $subtract (page 497) expression to subtract $date
from the current date:
db.sales.aggregate( [ { $project: { item: 1, dateDifference: { $subtract: [ new Date(), "$date" ] } } } ] )
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "dateDifference" : NumberLong("11713985194") }
{ "_id" : 2, "item" : "jkl", "dateDifference" : NumberLong("11710385194") }
Subtract Milliseconds from a Date The following aggregation uses the $subtract (page 497) expression to
subtract 5 * 60 * 1000 milliseconds (5 minutes) from the $date eld:
db.sales.aggregate( [ { $project: { item: 1, dateDifference: { $subtract: [ "$date", 5
*
60
*
1000 ] } } } ] )
The operation returns the following results:
{ "_id" : 1, "item" : "abc", "dateDifference" : ISODate("2014-03-01T07:55:00Z") }
{ "_id" : 2, "item" : "jkl", "dateDifference" : ISODate("2014-03-01T08:55:00Z") }
String Operators
String expressions, with the exception of $concat (page 499), only have a well-dened behavior for strings of ASCII
characters.
$concat (page 499) behavior is well-dened regardless of the characters used.
498 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
String Aggregation Operators String expressions, with the exception of $concat (page 499), only have a well-
dened behavior for strings of ASCII characters.
$concat (page 499) behavior is well-dened regardless of the characters used.
Name Description
$concat
(page 499)
Concatenates any number of strings.
$strcasecmp
(page 499)
Performs case-insensitive string comparison and returns: 0 if two strings are equivalent, 1 if
the rst string is greater than the second, and -1 if the rst string is less than the second.
$substr
(page 500)
Returns a substring of a string, starting at a specied index position up to a specied length.
Accepts three expressions as arguments: the rst argument must resolve to a string, and the
second and third arguments must resolve to integers.
$toLower
(page 501)
Converts a string to lowercase. Accepts a single argument expression.
$toUpper
(page 502)
Converts a string to uppercase. Accepts a single argument expression.
$concat (aggregation)
$concat
New in version 2.4.
Concatenates strings and returns the concatenated string.
$concat (page 499) has the following syntax:
{ $concat: [ <expression1>, <expression2>, ... ] }
The arguments can be any valid expression (page 537) as long as they resolve to strings. For more information
on expressions, see Expressions (page 537).
If the argument resolves to a value of null or refers to a eld that is missing, $concat (page 499) returns
null.
Examples Consider a inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : "product 1" }
{ "_id" : 2, "item" : "ABC2", quarter: "13Q4", "description" : "product 2" }
{ "_id" : 3, "item" : "XYZ1", quarter: "14Q2", "description" : null }
The following operation uses the $concat (page 499) operator to concatenate the item eld and the description
eld with a - delimiter.
db.inventory.aggregate(
[
{ $project: { itemDescription: { $concat: [ "$item", " - ", "$description" ] } } }
]
)
The operation returns the following results:
{ "_id" : 1, "itemDescription" : "ABC1 - product 1" }
{ "_id" : 2, "itemDescription" : "ABC2 - product 2" }
{ "_id" : 3, "itemDescription" : null }
$strcasecmp (aggregation)
2.3. Operators 499
MongoDB Reference Manual, Release 2.6.4
$strcasecmp
Performs case-insensitive comparison of two strings. Returns
1 if rst string is greater than the second string.
0 if the two strings are equal.
-1 if the rst string is less than the second string.
$strcasecmp (page 499) has the following syntax:
{ $strcasecmp: [ <expression1>, <expression2> ] }
The arguments can be any valid expression (page 537) as long as they resolve to strings. For more information
on expressions, see Expressions (page 537).
Behavior $strcasecmp (page 499) only has a well-dened behavior for strings of ASCII characters.
For a case sensitive comparison, see $cmp (page 488).
Example Consider a inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : "product 1" }
{ "_id" : 2, "item" : "ABC2", quarter: "13Q4", "description" : "product 2" }
{ "_id" : 3, "item" : "XYZ1", quarter: "14Q2", "description" : null }
The following operation uses the $strcasecmp (page 499) operator to perform case-insensitive comparison of the
quarter eld value to the string "13q3":
db.inventory.aggregate(
[
{
$project:
{
item: 1,
comparisonResult: { $strcasecmp: [ "$quarter", "13q3" ] }
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "ABC1", "comparisonResult" : -1 }
{ "_id" : 2, "item" : "ABC2", "comparisonResult" : 0 }
{ "_id" : 3, "item" : "XYZ1", "comparisonResult" : 1 }
$substr (aggregation)
$substr
Returns a substring of a string, starting at a specied index position and including the specied number of
characters. The index is zero-based.
$substr (page 500) has the following syntax:
{ $substr: [ <string>, <start>, <length> ] }
The arguments can be any valid expression (page 537) as long as long as the rst argument resolves to a string,
and the second and third arguments resolve to integers. For more information on expressions, see Expressions
(page 537).
500 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Behavior If <start> is a negative number, $substr (page 500) returns an empty string "".
If <length> is a negative number, $substr (page 500) returns a substring that starts at the specied index and
includes the rest of the string.
$substr (page 500) is not encoding aware and if used improperly may produce a result string containing an invalid
UTF-8 character sequence.
$substr (page 500) only has a well-dened behavior for strings of ASCII characters.
Example Consider an inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : "product 1" }
{ "_id" : 2, "item" : "ABC2", quarter: "13Q4", "description" : "product 2" }
{ "_id" : 3, "item" : "XYZ1", quarter: "14Q2", "description" : null }
The following operation uses the $substr (page 500) operator separate the quarter value into a
yearSubstring and a quarterSubstring:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
yearSubstring: { $substr: [ "$quarter", 0, 2 ] },
quarterSubtring: { $substr: [ "$quarter", 2, -1 ] }
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "ABC1", "yearSubstring" : "13", "quarterSubtring" : "Q1" }
{ "_id" : 2, "item" : "ABC2", "yearSubstring" : "13", "quarterSubtring" : "Q4" }
{ "_id" : 3, "item" : "XYZ1", "yearSubstring" : "14", "quarterSubtring" : "Q2" }
$toLower (aggregation)
$toLower
Converts a string to lowercase, returning the result.
$toLower (page 501) has the following syntax:
{ $toLower: <expression> }
The argument can be any expression (page 537) as long as it resolves to a string. For more information on
expressions, see Expressions (page 537).
If the argument resolves to null, $toLower (page 501) returns an empty string "".
Behavior $toLower (page 501) only has a well-dened behavior for strings of ASCII characters.
Example Consider a inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : "PRODUCT 1" }
{ "_id" : 2, "item" : "abc2", quarter: "13Q4", "description" : "Product 2" }
{ "_id" : 3, "item" : "xyz1", quarter: "14Q2", "description" : null }
2.3. Operators 501
MongoDB Reference Manual, Release 2.6.4
The following operation uses the $toLower (page 501) operator return lowercase item and lowercase
description value:
db.inventory.aggregate(
[
{
$project:
{
item: { $toLower: "$item" },
description: { $toLower: "$description" }
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "description" : "product 1" }
{ "_id" : 2, "item" : "abc2", "description" : "product 2" }
{ "_id" : 3, "item" : "xyz1", "description" : "" }
$toUpper (aggregation)
$toUpper
Converts a string to uppercase, returning the result.
$toUpper (page 502) has the following syntax:
{ $toUpper: <expression> }
The argument can be any expression (page 537) as long as it resolves to a string. For more information on
expressions, see Expressions (page 537).
If the argument resolves to null, $toLower (page 501) returns an empty string "".
Behavior $toUpper (page 502) only has a well-dened behavior for strings of ASCII characters.
Example Consider a inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", quarter: "13Q1", "description" : "PRODUCT 1" }
{ "_id" : 2, "item" : "abc2", quarter: "13Q4", "description" : "Product 2" }
{ "_id" : 3, "item" : "xyz1", quarter: "14Q2", "description" : null }
The following operation uses the $toUpper (page 502) operator return uppercase item and uppercase
description values:
db.inventory.aggregate(
[
{
$project:
{
item: { $toUpper: "$item" },
description: { $toUpper: "$description" }
}
}
]
)
502 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "_id" : 1, "item" : "ABC1", "description" : "PRODUCT 1" }
{ "_id" : 2, "item" : "ABC2", "description" : "PRODUCT 2" }
{ "_id" : 3, "item" : "XYZ1", "description" : "" }
Text Search Operators
Text Search Aggregation Operators
Name Description
$meta (page 503) Access text search metadata.
$meta (aggregation)
$meta
New in version 2.6.
Returns the metadata associated with a document in a pipeline operations, e.g. "textScore" when perform-
ing text search.
A $meta (page 503) expression has the following syntax:
{ $meta: <metaDataKeyword> }
The $meta (page 503) expression can specify the following keyword as the <metaDataKeyword>:
Key-
word
Description Sort
Or-
der
"textScore" Returns the score associated with the corresponding $text (page 401) query for each
matching document. The text score signies how well the document matched the
stemmed term or terms. If not used in conjunction with a $text (page 401) query,
returns a score of null.
De-
scend-
ing
Behavior The { $meta: "textScore" } expression is the only expression (page 537) that the $sort
(page 473) stage accepts.
Although available for use everywhere expressions are accepted in the pipeline, the { $meta: "textScore" }
expression is only meaningful in a pipeline that includes a $match (page 464) stage with a $text (page 401) query.
Examples Consider an articles collection with the following documents:
{ "_id" : 1, "title" : "cakes and ale" }
{ "_id" : 2, "title" : "more cakes" }
{ "_id" : 3, "title" : "bread" }
{ "_id" : 4, "title" : "some cakes" }
The following aggregation operation performs a text search and use the $meta (page 503) operator to group by the
text search score:
db.articles.aggregate(
[
{ $match: { $text: { $search: "cake" } } },
{ $group: { _id: { $meta: "textScore" }, count: { $sum: 1 } } }
]
)
2.3. Operators 503
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "_id" : 0.75, "count" : 1 }
{ "_id" : 1, "count" : 2 }
For more examples, see http://docs.mongodb.org/manualtutorial/text-search-in-aggregation.
Array Operators
Array Aggregation Operators
Name Description
$size (page 504) Returns the number of elements in the array. Accepts a single expression as argument.
$size (aggregation) New in version 2.6.
Denition
$size
Counts and returns the total the number of items in an array.
$size (page 504) has the following syntax:
{ $size: <expression> }
The argument for $size (page 504) can be any expression (page 537) as long as it resolves to an array. For
more information on expressions, see Expressions (page 537).
Example Consider a inventory collection with the following documents:
{ "_id" : 1, "item" : "ABC1", "description" : "product 1", colors: [ "blue", "black", "red" ] }
{ "_id" : 2, "item" : "ABC2", "description" : "product 2", colors: [ "purple" ] }
{ "_id" : 3, "item" : "XYZ1", "description" : "product 3", colors: [ ] }
The following aggregation pipeline operation use the $size (page 504) to return the number of elements in the
colors array:
db.inventory.aggregate(
[
{
$project: {
item: 1,
numberOfColors: { $size: "$colors" }
}
}
]
)
The operation returns the following:
{ "_id" : 1, "item" : "ABC1", "numberOfColors" : 3 }
{ "_id" : 2, "item" : "ABC2", "numberOfColors" : 1 }
{ "_id" : 3, "item" : "XYZ1", "numberOfColors" : 0 }
Variable Operators
504 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Aggregation Variable Operators
Name Description
$let
(page 505)
Denes variables for use within the scope of a subexpression and returns the result of the
subexpression. Accepts named parameters.
$map
(page 506)
Applies a subexpression to each element of an array and returns the array of resulting values in
order. Accepts named parameters.
$let (aggregation)
Denition
$let
Binds variables (page 545) for use in the specied expression, and returns the result of the expression.
The $let (page 505) expression has the following syntax:
{
$let:
{
vars: { <var1>: <expression>, ... },
in: <expression>
}
}
Field Specication
vars Assignment block for the variables (page 545) accessible in the in expression. To assign a variable,
specify a string for the variable name and assign a valid expression for the value.
The variable assignments have no meaning outside the in expression, not even within the vars
block itself.
in The expression (page 537) to evaluate.
To access variables in aggregation expressions, prex the variable name with double dollar signs ($$) and
enclosed in quotes. For more information on expressions, see Expressions (page 537). For information on use
of variables in the aggregation pipeline, see Variables in Aggregation Expressions (page 545).
Behavior $let (page 505) can access variables dened outside its expression block, including system variables
(page 545).
If you modify the values of externally dened variables in the vars block, the new values take effect only in the in
expression. Outside of the in expression, the variables retain their previous values.
In the vars assignment block, the order of the assignment does not matter, and the variable assignments only have
meaning inside the in expression. As such, accessing a variables value in the vars assignment block refers to the
value of the variable dened outside the vars block and not inside the same vars block.
For example, consider the following $let (page 505) expression:
{
$let:
{
vars: { low: 1, high: "$$low" },
in: { $gt: [ "$$low", "$$high" ] }
}
}
In the vars assignment block, "$$low" refers to the value of an externally dened variable low and not the variable
dened in the same vars block. If low is not dened outside this $let (page 505) expression block, the expression
is invalid.
2.3. Operators 505
MongoDB Reference Manual, Release 2.6.4
Example A sales collection has the following documents:
{ _id: 1, price: 10, tax: 0.50, applyDiscount: true }
{ _id: 2, price: 10, tax: 0.25, applyDiscount: false }
The following aggregation uses $let (page 505) in the $project (page 466) pipeline stage to calculate and return
the finalTotal for each document:
db.sales.aggregate( [
{
$project: {
finalTotal: {
$let: {
vars: {
total: { $add: [ '$price', '$tax' ] },
discounted: { $cond: { if: '$applyDiscount', then: 0.9, else: 1 } }
},
in: { $multiply: [ "$$total", "$$discounted" ] }
}
}
}
}
] )
The aggregation returns the following results:
{ "_id" : 1, "finalTotal" : 9.450000000000001 }
{ "_id" : 2, "finalTotal" : 10.25 }
See also:
$map (page 506)
$map (aggregation)
Denition
$map
Applies an expression (page 537) to each item in an array and returns an array with the applied results.
The $map (page 506) expression has the following syntax:
{ $map: { input: <expression>, as: <string>, in: <expression> } }
Field Specication
input An expression (page 537) that resolves to an array.
as The variable name for the items in the input array. The in expression accesses each item in the
input array by this variable (page 545).
in The expression (page 537) to apply to each item in the input array. The expression accesses the
item by its variable name.
For more information on expressions, see Expressions (page 537).
Example Consider a grades collection with the following documents:
{ _id: 1, quizzes: [ 5, 6, 7 ] }
{ _id: 2, quizzes: [ ] }
{ _id: 3, quizzes: [ 3, 8, 9 ] }
506 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
And the following $project (page 466) statement:
db.grades.aggregate(
[
{ $project:
{ adjustedGrades:
{
$map:
{
input: "$quizzes",
as: "grade",
in: { $add: [ "$$grade", 2 ] }
}
}
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "adjustedGrades" : [ 7, 8, 9 ] }
{ "_id" : 2, "adjustedGrades" : [ ] }
{ "_id" : 3, "adjustedGrades" : [ 5, 10, 11 ] }
See also:
$let (page 505)
Literal Operators
Aggregation Literal Operators
Name Description
$literal
(page 507)
Return a value without parsing. Use for values that the aggregation pipeline may interpret as an
expression. For example, use a $literal (page 507) expression to a string that starts with a $
to avoid parsing as a eld path.
$literal (aggregation)
Denition
$literal
Returns a value without parsing. Use for values that the aggregation pipeline may interpret as an expression.
The $literal (page 507) expression has the following syntax:
{ $literal: <value> }
Behavior If the <value> is an expression (page 537), $literal (page 507) does not evaluate the expression but
instead returns the unparsed expression.
Example Result
{ $literal: { $add: [ 2, 3 ] } } { "$add" : [ 2, 3 ] }
{ $literal: { $literal: 1 } } { "$literal" : 1 }
Examples
2.3. Operators 507
MongoDB Reference Manual, Release 2.6.4
Treat $ as a Literal In expression (page 537), the dollar sign $ evaluates to a eld path; i.e. provides access to the
eld. For example, the $eq expression $eq: [ "$price", "$1" ] performs an equality check between the
value in the eld named price and the value in the eld named 1 in the document.
The following example uses a $literal (page 507) expression to treat a string that contains a dollar sign "$1" as
a constant value.
A collection records has the following documents:
{ "_id" : 1, "item" : "abc123", price: "$2.50" }
{ "_id" : 2, "item" : "xyz123", price: "1" }
{ "_id" : 3, "item" : "ijk123", price: "$1" }
db.records.aggregate( [
{ $project: { costsOneDollar: { $eq: [ "$price", { $literal: "$1" } ] } } }
] )
This operation projects a eld named costsOneDollar that holds a boolean value, indicating whether the value of
the price eld is equal to the string "$1":
{ "_id" : 1, "costsOneDollar" : false }
{ "_id" : 2, "costsOneDollar" : false }
{ "_id" : 3, "costsOneDollar" : true }
Project a New Field with Value 1 The $project (page 466) stage uses the expression <field>: 1 to include
the <field> in the output. The following example uses the $literal (page 507) to return a new eld set to the
value of 1.
A collection bids has the following documents:
{ "_id" : 1, "item" : "abc123", condition: "new" }
{ "_id" : 2, "item" : "xyz123", condition: "new" }
The following aggregation evaluates the expression item: 1 to mean return the existing eld item in the output,
but uses the { $literal: 1 } (page 507) expression to return a new eld startAt set to the value 1:
db.bids.aggregate( [
{ $project: { item: 1, startAt: { $literal: 1 } } }
] )
The operation results in the following documents:
{ "_id" : 1, "item" : "abc123", "startAt" : 1 }
{ "_id" : 2, "item" : "xyz123", "startAt" : 1 }
Date Operators
508 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Date Aggregation Operators
Name Description
$dayOfMonth
(page 509)
Returns the day of the month for a date as a number between 1 and 31.
$dayOfWeek
(page 510)
Returns the day of the week for a date as a number between 1 (Sunday) and 7 (Saturday).
$dayOfYear
(page 511)
Returns the day of the year for a date as a number between 1 and 366 (leap year).
$hour (page 512) Returns the hour for a date as a number between 0 and 23.
$millisecond
(page 513)
Returns the milliseconds of a date as a number between 0 and 999.
$minute
(page 514)
Returns the minute for a date as a number between 0 and 59.
$month
(page 515)
Returns the month for a date as a number between 1 (January) and 12 (December).
$second
(page 515)
Returns the seconds for a date as a number between 0 and 60 (leap seconds).
$week (page 516) Returns the week number for a date as a number between 0 (the partial week that precedes
the rst Sunday of the year) and 53 (leap year).
$year (page 517) Returns the year for a date as a number (e.g. 2014).
$dayOfMonth (aggregation)
$dayOfMonth
Returns the day of the month for a date as a number between 1 and 31.
The $dayOfMonth (page 509) expression has the following syntax:
{ $dayOfMonth: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $dayOfMonth (page 509) and other date operators to break down the date
eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
2.3. Operators 509
MongoDB Reference Manual, Release 2.6.4
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$dayOfWeek (aggregation)
$dayOfWeek
Returns the day of the week for a date as a number between 1 (Sunday) and 7 (Saturday).
The $dayOfWeek (page 510) expression has the following syntax:
{ $dayOfWeek: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $dayOfWeek (page 510) and other date operators to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
510 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$dayOfYear (aggregation)
$dayOfYear
Returns the day of the year for a date as a number between 1 and 366.
The $dayOfYear (page 511) expression has the following syntax:
{ $dayOfYear: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $dayOfYear (page 511) and other date expressions to break down the date
eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
2.3. Operators 511
MongoDB Reference Manual, Release 2.6.4
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$hour (aggregation)
$hour
Returns the hour portion of a date as a number between 0 and 23.
The $hour (page 512) expression has the following syntax:
{ $hour: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $hour (page 512) and other date expressions to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
512 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$millisecond (aggregation)
$millisecond
Returns the millisecond portion of a date as an integer between 0 and 999.
The $millisecond (page 513) expression has the following syntax:
{ $millisecond: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $millisecond (page 513) and other date operators to break down the date
eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
2.3. Operators 513
MongoDB Reference Manual, Release 2.6.4
"week" : 0
}
$minute (aggregation)
$minute
Returns the minute portion of a date as a number between 0 and 59.
The $minute (page 514) expression has the following syntax:
{ $minute: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $minute (page 514) and other date expressions to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
514 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
$month (aggregation)
$month
Returns the month of a date as a number between 1 and 12.
The $month (page 515) expression has the following syntax:
{ $month: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $month (page 515) and other date operators to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$second (aggregation)
$second
Returns the second portion of a date as a number between 0 and 59, but can be 60 to account for leap seconds.
The $second (page 515) expression has the following syntax:
2.3. Operators 515
MongoDB Reference Manual, Release 2.6.4
{ $second: <expression> }
The argument can be any valid expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $second (page 515) and other date expressions to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$week (aggregation)
$week
Returns the week of the year for a date as a number between 0 and 53.
Weeks begin on Sundays, and week 1 begins with the rst Sunday of the year. Days preceding the rst Sunday
of the year are in week 0. This behavior is the same as the %U operator to the strftime standard library
function.
The $week (page 516) expression has the following syntax:
516 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ $week: <expression> }
The argument can be any valid expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
Example Consider a sales collection with the following document:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $week (page 516) and other date operators to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
$year (aggregation)
$year
Returns the year portion of a date.
The $year (page 517) expression has the following syntax:
{ $year: <expression> }
The argument can be any expression (page 537) as long as it resolves to a date. For more information on
expressions, see Expressions (page 537).
2.3. Operators 517
MongoDB Reference Manual, Release 2.6.4
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:15:39.736Z") }
The following aggregation uses the $year (page 517) and other date operators to break down the date eld:
db.sales.aggregate(
[
{
$project:
{
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
hour: { $hour: "$date" },
minutes: { $minute: "$date" },
seconds: { $second: "$date" },
milliseconds: { $millisecond: "$date" },
dayOfYear: { $dayOfYear: "$date" },
dayOfWeek: { $dayOfWeek: "$date" },
week: { $week: "$date" }
}
}
]
)
The operation returns the following result:
{
"_id" : 1,
"year" : 2014,
"month" : 1,
"day" : 1,
"hour" : 8,
"minutes" : 15,
"seconds" : 39,
"milliseconds" : 736,
"dayOfYear" : 1,
"dayOfWeek" : 4,
"week" : 0
}
Conditional Expressions
Conditional Aggregation Operators
Name Description
$cond
(page 518)
A ternary operator that evaluates one expression, and depending on the result, returns the value of
one of the other two expressions. Accepts either three expressions in an ordered list or three
named parameters.
$ifNull
(page 520)
Returns either the non-null result of the rst expression or the result of the second expression if
the rst expression results in a null result. Null result encompasses instances of undened values
or missing elds. Accepts two expressions as arguments. The result of the second expression can
be null.
$cond (aggregation)
$cond
Evaluates a boolean expression to return one of the two specied return expressions.
518 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $cond (page 518) expression has one of two syntaxes:
New in version 2.6.
{ $cond: { if: <boolean-expression>, then: <true-case>, else: <false-case-> } }
Or:
{ $cond: [ <boolean-expression>, <true-case>, <false-case> ] }
If the <boolean-expression> evaluates to true, then $cond (page 518) evaluates and returns the
value of the <true-case> expression. Otherwise, $cond (page 518) evaluates and returns the value of
the <false-case> expression.
The arguments can be any valid expression (page 537). For more information on expressions, see Expressions
(page 537).
Example The following example use a inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", qty: 300 }
{ "_id" : 2, "item" : "abc2", qty: 200 }
{ "_id" : 3, "item" : "xyz1", qty: 250 }
The following aggregation operation uses the $cond (page 518) expression to set the discount value to 30 if qty
value is greater than or equal to 250 and to 20 if qty value is less than 250:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
discount:
{
$cond: { if: { $gte: [ "$qty", 250 ] }, then: 30, else: 20 }
}
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "discount" : 30 }
{ "_id" : 2, "item" : "abc2", "discount" : 20 }
{ "_id" : 3, "item" : "xyz1", "discount" : 30 }
The following operation uses the array syntax of the $cond (page 518) expression and returns the same results:
db.inventory.aggregate(
[
{
$project:
{
item: 1,
discount:
{
$cond: [ { $gte: [ "$qty", 250 ] }, 30, 20 ]
}
}
2.3. Operators 519
MongoDB Reference Manual, Release 2.6.4
}
]
)
$ifNull (aggregation)
$ifNull
Evaluates an expression and returns the value of the expression if the expression evaluates to a non-null value.
If the expression evaluates to a null value, including instances of undened values or missing elds, returns the
value of the replacement expression.
The $ifNull (page 520) expression has the following syntax:
{ $ifNull: [ <expression>, <replacement-expression-if-null> ] }
The arguments can be any valid expression (page 537). For more information on expressions, see Expressions
(page 537).
Example The following example use a inventory collection with the following documents:
{ "_id" : 1, "item" : "abc1", description: "product 1", qty: 300 }
{ "_id" : 2, "item" : "abc2", description: null, qty: 200 }
{ "_id" : 3, "item" : "xyz1", qty: 250 }
The following operation uses the $ifNull (page 520) expression to return either the non-null description eld
value or the string "Unspecified" if the description eld is null or does not exist:
db.inventory.aggregate(
[
{
$project: {
item: 1,
description: { $ifNull: [ "$description", "Unspecified" ] }
}
}
]
)
The operation returns the following results:
{ "_id" : 1, "item" : "abc1", "description" : "product 1" }
{ "_id" : 2, "item" : "abc2", "description" : "Unspecified" }
{ "_id" : 3, "item" : "xyz1", "description" : "Unspecified" }
Accumulators
Accumulators, available only for the $group (page 460) stage, compute values by combining documents that share
the same group key. Accumulators take as input a single expression, evaluating the expression once for each input
document, and maintain their state for the group of documents.
Group Accumulator Operators
Accumulators, available only for the $group (page 460) stage, compute values by combining documents that share
the same group key. Accumulators take as input a single expression, evaluating the expression once for each input
document, and maintain their state for the group of documents.
520 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Name Description
$addToSet
(page 521)
Returns an array of unique expression values for each group. Order of the array elements is
undened.
$avg (page 522) Returns an average for each group. Ignores non-numeric values.
$first
(page 522)
Returns a value from the rst document for each group. Order is only dened if the
documents are in a dened order.
$last (page 523) Returns a value from the last document for each group. Order is only dened if the
documents are in a dened order.
$max (page 524) Returns the highest expression value for each group.
$min (page 525) Returns the lowest expression value for each group.
$push (page 526) Returns an array of expression values for each group.
$sum (page 527) Returns a sum for each group. Ignores non-numeric values.
$addToSet (aggregation)
$addToSet
Returns an array of all unique values that results from applying an expression to each document in a group of
documents that share the same group by key. Order of the elements in the output array is unspecied.
$addToSet (page 521) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$addToSet has the following syntax:
{ $addToSet: <expression> }
For more information on expressions, see Expressions (page 537).
Behavior If the value of the expression is an array, $addToSet (page 521) appends the whole array as a single
element.
If the value of the expression is a document, MongoDBdetermines that the document is a duplicate if another document
in the array matches the to-be-added document exactly; i.e. the existing document has the exact same elds and values
in the exact same order.
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:12:00Z") }
Grouping the documents by the day and the year of the date eld, the following operation uses the $addToSet
(page 521) accumulator to compute the list of unique items sold for each group:
db.sales.aggregate(
[
{
$group:
{
_id: { day: { $dayOfYear: "$date"}, year: { $year: "$date" } },
itemsSold: { $addToSet: "$item" }
}
}
]
)
2.3. Operators 521
MongoDB Reference Manual, Release 2.6.4
The operation returns the following results:
{ "_id" : { "day" : 46, "year" : 2014 }, "itemsSold" : [ "xyz", "abc" ] }
{ "_id" : { "day" : 34, "year" : 2014 }, "itemsSold" : [ "xyz", "jkl" ] }
{ "_id" : { "day" : 1, "year" : 2014 }, "itemsSold" : [ "abc" ] }
$avg (aggregation)
$avg
Returns the average value of the numeric values that result from applying a specied expression to each docu-
ment in a group of documents that share the same group by key. $avg (page 522) ignores non-numeric values.
$avg (page 522) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$avg has the following syntax:
{ $avg: <expression> }
For more information on expressions, see Expressions (page 537).
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:12:00Z") }
Grouping the documents by the item eld, the following operation uses the $avg (page 522) accumulator to compute
the average amount and average quantity for each grouping.
db.sales.aggregate(
[
{
$group:
{
_id: "$item",
avgAmount: { $avg: { $multiply: [ "$price", "$quantity" ] } },
avgQuantity: { $avg: "$quantity" }
}
}
]
)
The operation returns the following results:
{ "_id" : "xyz", "avgAmount" : 37.5, "avgQuantity" : 7.5 }
{ "_id" : "jkl", "avgAmount" : 20, "avgQuantity" : 1 }
{ "_id" : "abc", "avgAmount" : 60, "avgQuantity" : 6 }
$rst (aggregation)
$first
Returns the value that results from applying an expression to the rst document in a group of documents that
share the same group by key. Only meaningful when documents are in a dened order.
$first (page 522) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$first has the following syntax:
522 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ $first: <expression> }
For more information on expressions, see Expressions (page 537).
Behavior When using $first (page 522) in a $group (page 460) stage, the $group (page 460) stage should
follow a $sort (page 473) stage to have the input documents in a dened order.
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
{ "_id" : 6, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-15T12:05:10Z") }
{ "_id" : 7, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T14:12:12Z") }
Grouping the documents by the item eld, the following operation uses the $first (page 522) accumulator to
compute the rst sales date for each item:
db.sales.aggregate(
[
{ $sort: { item: 1, date: 1 } },
{
$group:
{
_id: "$item",
firstSalesDate: { $first: "$date" }
}
}
]
)
The operation returns the following results:
{ "_id" : "xyz", "firstSalesDate" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : "jkl", "firstSalesDate" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : "abc", "firstSalesDate" : ISODate("2014-01-01T08:00:00Z") }
$last (aggregation)
$last
Returns the value that results from applying an expression to the last document in a group of documents that
share the same group by key. Only meaningful when documents are in a dened order.
$last (page 523) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$last has the following syntax:
{ $last: <expression> }
For more information on expressions, see Expressions (page 537).
Behavior When using $last (page 523) in a $group (page 460) stage, the $group (page 460) stage should
follow a $sort (page 473) stage to have the input documents in a dened order.
2.3. Operators 523
MongoDB Reference Manual, Release 2.6.4
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
{ "_id" : 6, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-15T12:05:10Z") }
{ "_id" : 7, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T14:12:12Z") }
Grouping the documents by the item eld, the following operation uses the $last (page 523) accumulator to
compute the last sales date for each item:
db.sales.aggregate(
[
{ $sort: { item: 1, date: 1 } },
{
$group:
{
_id: "$item",
lastSalesDate: { $last: "$date" }
}
}
]
)
The operation returns the following results:
{ "_id" : "xyz", "lastSalesDate" : ISODate("2014-02-15T14:12:12Z") }
{ "_id" : "jkl", "lastSalesDate" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : "abc", "lastSalesDate" : ISODate("2014-02-15T08:00:00Z") }
$max (aggregation)
$max
Returns the highest value that results from applying an expression to each document in a group of documents
that share the same group by key.
$max (page 524) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$max has the following syntax:
{ $max: <expression> }
For more information on expressions, see Expressions (page 537).
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
Grouping the documents by the item eld, the following operation uses the $max (page 524) accumulator to compute
the maximum total amount and maximum quantity for each group of documents.
db.sales.aggregate(
[
524 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{
$group:
{
_id: "$item",
maxTotalAmount: { $max: { $multiply: [ "$price", "$quantity" ] } },
maxQuantity: { $max: "$quantity" }
}
}
]
)
The operation returns the following results:
{ "_id" : "xyz", "maxTotalAmount" : 50, "maxQuantity" : 10 }
{ "_id" : "jkl", "maxTotalAmount" : 20, "maxQuantity" : 1 }
{ "_id" : "abc", "maxTotalAmount" : 100, "maxQuantity" : 10 }
$min (aggregation)
$min
Returns the lowest value that results from applying an expression to each document in a group of documents
that share the same group by key.
$min (page 525) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$min has the following syntax:
{ $min: <expression> }
For more information on expressions, see Expressions (page 537).
Behavior Changed in version 2.4.
If some, but not all, documents for the $min (page 525) operation have either a null value for the eld or are
missing the eld, the $min (page 525) operator only considers the non-null and the non-missing values for the eld.
If all documents for the $min (page 525) operation have null value for the eld or are missing the eld, the $min
(page 525) operator returns null for the minimum value.
Before 2.4, if any of the documents for the $min (page 525) operation were missing the eld, the $min (page 525)
operator would not return any value. If any of the documents for the $min (page 525) had the value null, the $min
(page 525) operator would return a null.
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
Grouping the documents by the item eld, the following operation uses the $min (page 525) accumulator to compute
the minimum amount and minimum quantity for each grouping.
db.sales.aggregate(
[
{
$group:
2.3. Operators 525
MongoDB Reference Manual, Release 2.6.4
{
_id: "$item",
minQuantity: { $min: "$quantity" }
}
}
]
)
The operation returns the following results:
{ "_id" : "xyz", "minQuantity" : 5 }
{ "_id" : "jkl", "minQuantity" : 1 }
{ "_id" : "abc", "minQuantity" : 2 }
$push (aggregation)
$push
Returns an array of all values that result from applying an expression to each document in a group of documents
that share the same group by key.
$push (page 526) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$push has the following syntax:
{ $push: <expression> }
For more information on expressions, see Expressions (page 537).
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
{ "_id" : 6, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-15T12:05:10Z") }
{ "_id" : 7, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T14:12:12Z") }
Grouping the documents by the day and the year of the date eld, the following operation uses the $addToSet
(page 521) accumulator to compute the list of items and quantities sold for each group:
db.sales.aggregate(
[
{
$group:
{
_id: { day: { $dayOfYear: "$date"}, year: { $year: "$date" } },
itemsSold: { $push: { item: "$item", quantity: "$quantity" } }
}
}
]
)
The operation returns the following results:
{
"_id" : { "day" : 46, "year" : 2014 },
"itemsSold" : [
{ "item" : "abc", "quantity" : 10 },
526 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
{ "item" : "xyz", "quantity" : 10 },
{ "item" : "xyz", "quantity" : 5 },
{ "item" : "xyz", "quantity" : 10 }
]
}
{
"_id" : { "day" : 34, "year" : 2014 },
"itemsSold" : [
{ "item" : "jkl", "quantity" : 1 },
{ "item" : "xyz", "quantity" : 5 }
]
}
{
"_id" : { "day" : 1, "year" : 2014 },
"itemsSold" : [ { "item" : "abc", "quantity" : 2 } ]
}
$sum (aggregation)
$sum
Calculates and returns the sum of all the numeric values that result from applying a specied expression to each
document in a group of documents that share the same group by key. $sum (page 527) ignores non-numeric
values.
$sum (page 527) is an accumulator operator (page 520) available only in the $group (page 460) stage.
$sum has the following syntax:
{ $sum: <expression> }
For more information on expressions, see Expressions (page 537).
Example Consider a sales collection with the following documents:
{ "_id" : 1, "item" : "abc", "price" : 10, "quantity" : 2, "date" : ISODate("2014-01-01T08:00:00Z") }
{ "_id" : 2, "item" : "jkl", "price" : 20, "quantity" : 1, "date" : ISODate("2014-02-03T09:00:00Z") }
{ "_id" : 3, "item" : "xyz", "price" : 5, "quantity" : 5, "date" : ISODate("2014-02-03T09:05:00Z") }
{ "_id" : 4, "item" : "abc", "price" : 10, "quantity" : 10, "date" : ISODate("2014-02-15T08:00:00Z") }
{ "_id" : 5, "item" : "xyz", "price" : 5, "quantity" : 10, "date" : ISODate("2014-02-15T09:05:00Z") }
Grouping the documents by the day and the year of the date eld, the following operation uses the $sum (page 527)
accumulator to compute the total amount and the count for each group of documents.
db.sales.aggregate(
[
{
$group:
{
_id: { day: { $dayOfYear: "$date"}, year: { $year: "$date" } },
totalAmount: { $sum: { $multiply: [ "$price", "$quantity" ] } },
count: { $sum: 1 }
}
}
]
)
The operation returns the following results:
2.3. Operators 527
MongoDB Reference Manual, Release 2.6.4
{ "_id" : { "day" : 46, "year" : 2014 }, "totalAmount" : 150, "count" : 2 }
{ "_id" : { "day" : 34, "year" : 2014 }, "totalAmount" : 45, "count" : 2 }
{ "_id" : { "day" : 1, "year" : 2014 }, "totalAmount" : 20, "count" : 1 }
2.3.4 Query Modiers
Introduction
In addition to the MongoDB Query Operators (page 386), there are a number of meta operators that let you modify
the output or behavior of a query. On the server, MongoDB treats the query and the options as a single object. The
mongo (page 580) shell and driver interfaces may provide cursor methods (page 79) that wrap these options. When
possible, use these methods; otherwise, you can add these options using either of the following syntax:
db.collection.find( { <query> } )._addSpecial( <option> )
db.collection.find( { $query: { <query> }, <option> } )
Operators
Modiers
Many of these operators have corresponding methods in the shell (page 79). These methods provide a straightforward
and user-friendly interface and are the preferred way to add these options.
Name Description
$comment
(page 528)
Adds a comment to the query to identify queries in the database proler output.
$explain
(page 529)
Forces MongoDB to report on query execution plans. See explain() (page 83).
$hint (page 529) Forces MongoDB to use a specic index. See hint() (page 88)
$maxScan
(page 530)
Limits the number of documents scanned.
$maxTimeMS
(page 530)
Species a cumulative time limit in milliseconds for processing operations on a cursor.
See maxTimeMS() (page 91).
$max (page 530) Species an exclusive upper limit for the index to use in a query. See max() (page 90).
$min (page 531) Species an inclusive lower limit for the index to use in a query. See min() (page 92).
$orderby
(page 532)
Returns a cursor with documents sorted according to a sort specication. See sort()
(page 96).
$query (page 532) Wraps a query document.
$returnKey
(page 533)
Forces the cursor to only return elds included in the index.
$showDiskLoc
(page 533)
Modies the documents returned to include references to the on-disk location of each
document.
$snapshot
(page 534)
Forces the query to use the index on the _id eld. See snapshot() (page 96).
$comment
$comment
The $comment (page 528) makes it possible to attach a comment to a query. Because these comments propa-
gate to the profile (page 353) log, adding $comment (page 528) modiers can make your prole data much
easier to interpret and trace. Use one of the following forms:
528 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
db.collection.find( { <query> } )._addSpecial( "$comment", <comment> )
db.collection.find( { $query: { <query> }, $comment: <comment> } )
$explain
$explain
The $explain (page 529) operator provides information on the query plan. It returns a document that de-
scribes the process and indexes used to return the query. This may provide useful insight when attempting to
optimize a query. For details on the output, see cursor.explain() (page 83).
You can specify the $explain (page 529) operator in either of the following forms:
db.collection.find()._addSpecial( "$explain", 1 )
db.collection.find( { $query: {}, $explain: 1 } )
You also can specify $explain (page 529) through the explain() (page 83) method in the mongo
(page 580) shell:
db.collection.find().explain()
Behavior $explain (page 529) runs the actual query to determine the result. Although there are some differences
between running the query with $explain (page 529) and running without, generally, the performance will be
similar between the two. So, if the query is slow, the $explain (page 529) operation is also slow.
Additionally, the $explain (page 529) operation reevaluates a set of candidate query plans, which may cause the
$explain (page 529) operation to perform differently than a normal query. As a result, these operations generally
provide an accurate account of how MongoDB would perform the query, but do not reect the length of these queries.
See also:
explain() (page 83)
http://docs.mongodb.org/manualadministration/optimization page for information re-
garding optimization strategies.
http://docs.mongodb.org/manualtutorial/manage-the-database-profiler tutorial
for information regarding the database prole.
Current Operation Reporting (page 107)
$hint
$hint
The $hint (page 529) operator forces the query optimizer to use a specic index to fulll the query. Specify
the index either by the index name or by document.
Use $hint (page 529) for testing query performance and indexing strategies. The mongo (page 580) shell
provides a helper method hint() (page 88) for the $hint (page 529) operator.
Consider the following operation:
db.users.find().hint( { age: 1 } )
This operation returns all documents in the collection named users using the index on the age eld.
You can also specify a hint using either of the following forms:
db.users.find()._addSpecial( "$hint", { age : 1 } )
db.users.find( { $query: {}, $hint: { age : 1 } } )
2.3. Operators 529
MongoDB Reference Manual, Release 2.6.4
Note: When the query species the $hint (page 529) in the following form:
db.users.find( { $query: {}, $hint: { age : 1 } } )
Then, in order to include the $explain (page 529) option, you must add the $explain (page 529) option to
the document, as in the following:
db.users.find( { $query: {}, $hint: { age : 1 }, $explain: 1 } )
When an index lter exists for the query shape, MongoDB ignores the $hint (page 529). The
explain.filterSet (page 87) eld of the explain() (page 83) output indicates whether MongoDB
applied an index lter for the query.
$maxScan
$maxScan
Constrains the query to only scan the specied number of documents when fullling the query. Use one of the
following forms:
db.collection.find( { <query> } )._addSpecial( "$maxScan" , <number> )
db.collection.find( { $query: { <query> }, $maxScan: <number> } )
Use this modier to prevent potentially long running queries from disrupting performance by scanning through
too much data.
$maxTimeMS
$maxTimeMS
New in version 2.6: The $maxTimeMS (page 530) operator species a cumulative time limit in milliseconds
for processing operations on the cursor. MongoDB interrupts the operation at the earliest following interrupt
point.
The mongo (page 580) shell provides the cursor.maxTimeMS() (page 91) method
db.collection.find().maxTimeMS(100)
You can also specify the option in either of the following forms:
db.collection.find( $query: { } , $maxTimeMS: 100 } )
db.collection.find()._addSpecial("$maxTimeMS", 100)
Interrupted operations return an error message similar to the following:
error: { "$err" : "operation exceeded time limit", "code" : 50 }
$max
$max
Specify a $max (page 530) value to specify the exclusive upper bound for a specic index in order to constrain
the results of find() (page 33). The mongo (page 580) shell provides the max() (page 90) wrapper method:
db.collection.find( { <query> } ).max( { field1: <max value>, ... fieldN: <max valueN> } )
You can also specify the option with either of the two forms:
db.collection.find( { <query> } )._addSpecial( "$max", { field1: <max value1>, ... fieldN: <max valueN> } )
db.collection.find( { $query: { <query> }, $max: { field1: <max value1>, ... fieldN: <max valueN> } } )
530 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
The $max (page 530) species the upper bound for all keys of a specic index in order.
Consider the following operations on a collection named collection that has an index { age: 1 }:
db.collection.find( { <query> } ).max( { age: 100 } )
This operation limits the query to those documents where the eld age is less than 100 using the index {
age: 1 }.
You can explicitly specify the corresponding index with hint() (page 88). Otherwise, MongoDB selects the
index using the elds in the indexBounds; however, if multiple indexes exist on same elds with different
sort orders, the selection of the index may be ambiguous.
Consider a collection named collection that has the following two indexes:
{ age: 1, type: -1 }
{ age: 1, type: 1 }
Without explicitly using hint() (page 88), MongoDB may select either index for the following operation:
db.collection.find().max( { age: 50, type: 'B' } )
Use $max (page 530) alone or in conjunction with $min (page 531) to limit results to a specic range for the
same index, as in the following example:
db.collection.find().min( { age: 20 } ).max( { age: 25 } )
Note: Because max() (page 90) requires an index on a eld, and forces the query to use this index, you may
prefer the $lt (page 388) operator for the query if possible. Consider the following example:
db.collection.find( { _id: 7 } ).max( { age: 25 } )
The query uses the index on the age eld, even if the index on _id may be better.
$min
$min
Specify a $min (page 531) value to specify the inclusive lower bound for a specic index in order to constrain
the results of find() (page 33). The mongo (page 580) shell provides the min() (page 92) wrapper method:
db.collection.find( { <query> } ).min( { field1: <min value>, ... fieldN: <min valueN>} )
You can also specify the option with either of the two forms:
db.collection.find( { <query> } )._addSpecial( "$min", { field1: <min value1>, ... fieldN: <min valueN> } )
db.collection.find( { $query: { <query> }, $min: { field1: <min value1>, ... fieldN: <min valueN> } } )
The $min (page 531) species the lower bound for all keys of a specic index in order.
Consider the following operations on a collection named collection that has an index { age: 1 }:
db.collection.find().min( { age: 20 } )
These operations limit the query to those documents where the eld age is at least 20 using the index { age:
1 }.
You can explicitly specify the corresponding index with hint() (page 88). Otherwise, MongoDB selects the
index using the elds in the indexBounds; however, if multiple indexes exist on same elds with different
sort orders, the selection of the index may be ambiguous.
Consider a collection named collection that has the following two indexes:
2.3. Operators 531
MongoDB Reference Manual, Release 2.6.4
{ age: 1, type: -1 }
{ age: 1, type: 1 }
Without explicitly using hint() (page 88), it is unclear which index the following operation will select:
db.collection.find().min( { age: 20, type: 'C' } )
You can use $min (page 531) in conjunction with $max (page 530) to limit results to a specic range for the
same index, as in the following example:
db.collection.find().min( { age: 20 } ).max( { age: 25 } )
Note: Because min() (page 92) requires an index on a eld, and forces the query to use this index, you may
prefer the $gte (page 387) operator for the query if possible. Consider the following example:
db.collection.find( { _id: 7 } ).min( { age: 25 } )
The query will use the index on the age eld, even if the index on _id may be better.
$orderby
$orderby
The $orderby (page 532) operator sorts the results of a query in ascending or descending order.
The mongo (page 580) shell provides the cursor.sort() (page 96) method:
db.collection.find().sort( { age: -1 } )
You can also specify the option in either of the following forms:
db.collection.find()._addSpecial( "$orderby", { age : -1 } )
db.collection.find( { $query: {}, $orderby: { age : -1 } } )
These examples return all documents in the collection named collection sorted by the age eld in descend-
ing order. Specify a value to $orderby (page 532) of negative one (e.g. -1, as above) to sort in descending
order or a positive value (e.g. 1) to sort in ascending order.
Behavior The sort function requires that the entire sort be able to complete within 32 megabytes. When the sort
option consumes more than 32 megabytes, MongoDB will return an error.
To avoid this error, create an index to support the sort operation or use $orderby (page 532) in conjunction with
$maxScan (page 530) and/or cursor.limit() (page 89). The cursor.limit() (page 89) increases the speed
and reduces the amount of memory required to return this query by way of an optimized algorithm. The specied limit
must result in a number of documents that fall within the 32 megabyte limit.
$query
$query
The $query (page 532) operator provides an interface to describe queries. Consider the following operation:
db.collection.find( { $query: { age : 25 } } )
This is equivalent to the more familiar db.collection.find() (page 33) method:
db.collection.find( { age : 25 } )
These operations return only those documents in the collection named collection where the age eld
equals 25.
532 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Note: Do not mix query forms. If you use the $query (page 532) format, do not append cursor methods
(page 79) to the find() (page 33). To modify the query use the meta-query operators (page 528), such as
$explain (page 529).
Therefore, the following two operations are equivalent:
db.collection.find( { $query: { age : 25 }, $explain: true } )
db.collection.find( { age : 25 } ).explain()
See also:
For more information about queries in MongoDBsee http://docs.mongodb.org/manualcore/read-operations,
db.collection.find() (page 33), and http://docs.mongodb.org/manualtutorial/getting-started.
$returnKey
$returnKey
Only return the index eld or elds for the results of the query. If $returnKey (page 533) is set to true
and the query does not use an index to perform the read operation, the returned documents will not contain any
elds. Use one of the following forms:
db.collection.find( { <query> } )._addSpecial( "$returnKey", true )
db.collection.find( { $query: { <query> }, $returnKey: true } )
$showDiskLoc
$showDiskLoc
$showDiskLoc (page 533) option adds a eld $diskLoc to the returned documents. The value of the added
$diskLoc eld is a document that contains the disk location information:
"$diskLoc": {
"file": <int>,
"offset": <int>
}
The mongo (page 580) shell provides the cursor.showDiskLoc() (page 94) method for $showDiskLoc
(page 533):
db.collection.find().showDiskLoc()
You can also specify the $showDiskLoc (page 533) option in either of the following forms:
db.collection.find( { <query> } )._addSpecial("$showDiskLoc" , true)
db.collection.find( { $query: { <query> }, $showDiskLoc: true } )
Example The following operation appends the showDiskLoc() (page 94) method to the
db.collection.find() (page 33) method in order to include in the matching documents the disk loca-
tion information:
db.collection.find( { a: 1 } ).showDiskLoc()
The operation returns the following documents, which includes the $diskLoc eld:
{
"_id" : ObjectId("53908ccb18facd50a75bfbac"),
"a" : 1,
"b" : 1,
2.3. Operators 533
MongoDB Reference Manual, Release 2.6.4
"$diskLoc" : { "file" : 0, "offset" : 16195760 }
}
{
"_id" : ObjectId("53908cd518facd50a75bfbad"),
"a" : 1,
"b" : 2,
"$diskLoc" : { "file" : 0, "offset" : 16195824 }
}
The projection can also access the added eld $diskLoc, as in the following example:
db.collection.find( { a: 1 }, { $diskLoc: 1 } ).showDiskLoc()
The operation returns just the _id eld and the $diskLoc eld in the matching documents:
{
"_id" : ObjectId("53908ccb18facd50a75bfbac"),
"$diskLoc" : { "file" : 0, "offset" : 16195760 }
}
{
"_id" : ObjectId("53908cd518facd50a75bfbad"),
"$diskLoc" : { "file" : 0, "offset" : 16195824 }
}
$snapshot
$snapshot
The $snapshot (page 534) operator prevents the cursor from returning a document more than once because
an intervening write operation results in a move of the document.
Even in snapshot mode, objects inserted or deleted during the lifetime of the cursor may or may not be returned.
The mongo (page 580) shell provides the cursor.snapshot() (page 96) method:
db.collection.find().snapshot()
You can also specify the option in either of the following forms:
db.collection.find()._addSpecial( "$snapshot", true )
db.collection.find( { $query: {}, $snapshot: true } )
The $snapshot (page 534) operator traverses the index on the _id eld
32
.
Warning:
You cannot use $snapshot (page 534) with sharded collections.
Do not use $snapshot (page 534) with $hint (page 529) or $orderby (page 532) (or the corre-
sponding cursor.hint() (page 88) and cursor.sort() (page 96) methods.)
Sort Order
Name Description
$natural (page 535) A special sort order that orders documents using the order of documents on disk.
$natural
32
You can achieve the $snapshot (page 534) isolation behavior using any unique index on invariable elds.
534 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Denition
$natural
Use the $natural (page 535) operator to use natural order for the results of a sort operation. Natural order
refers to the storage order (page 99) of documents in the le on disk.
The $natural (page 535) operator uses the following syntax to return documents in the order they exist on
disk:
db.collection.find().sort( { $natural: 1 } )
Behavior On a sharded collection the $natural (page 535) operator returns a collection scan sorted in storage
order (page 99), the order the database inserts and stores documents on disk.
You cannot specify $natural (page 535) sort order if the query includes a $text (page 401) expression.
Examples
Reverse Order Use -1 to return documents in the reverse order as they occur on disk:
db.collection.find().sort( { $natural: -1 } )
Natural Order Comparison To demonstrate natural ordering:
Create an { normal: 1 } index on a collection (e.g. coll).
Insert relevant objects with _id and normal values, for example, a document with _id and normal elds
that both hold the same string:
db.coll.insert( { _id: "01", normal: "01" } )
Use values with different types for each document, but both elds in the document should have the same value:
Use .find().sort().explain() for all operations.
This scenario returns these results when using find() (page 33) for different _id values; sorting with the
$natural (page 535) operator, _id index, and normal index; and a description of the explain() (page 83)
method output:
sort() (page 96)
find()
(page 33)
$natural (page 535):1 _id:1 normal:1
_id:ObjectId() explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
_id:Object() explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
_id:string() explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
_id:integer()explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
_id:BinData()explain() (page 83) scanned
entire collection
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
normal:(any
query)
explain() (page 83) scanned
entire collection
explain() (page 83) used
B-Tree cursor
explain() (page 83) used
B-Tree cursor
Additional Information cursor.sort() (page 96)
2.3. Operators 535
MongoDB Reference Manual, Release 2.6.4
2.4 Aggregation Reference
Aggregation Pipeline Quick Reference (page 536) Quick reference card for aggregation pipeline.
Aggregation Pipeline Operators (page 456) Aggregation pipeline operations have a collection of operators available
to dene and manipulate documents in pipeline stages.
Aggregation Commands Comparison (page 541) A comparison of group (page 214), mapReduce (page 218) and
aggregate (page 208) that explores the strengths and limitations of each aggregation modality.
SQL to Aggregation Mapping Chart (page 552) An overview common aggregation operations in SQL and Mon-
goDB using the aggregation pipeline and operators in MongoDB and common SQL statements.
Aggregation Interfaces (page 545) The data aggregation interfaces document the invocation format and output for
MongoDBs aggregation commands and methods.
Variables in Aggregation Expressions (page 545) Use of variables in aggregation pipeline expressions.
2.4.1 Aggregation Pipeline Quick Reference
Stages
Pipeline stages appear in an array. Documents pass through the stages in sequence. All except the $out (page 465)
and $geoNear (page 458) stages can appear multiple times in a pipeline.
db.collection.aggregate( [ { <stage> }, ... ] )
536 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Name Description
$geoNear
(page 458)
Returns an ordered stream of documents based on the proximity to a geospatial point.
Incorporates the functionality of $match (page 464), $sort (page 473), and $limit
(page 463) for geospatial data. The output documents include an additional distance eld and can
include a location identier eld.
$group
(page 460)
Groups input documents by a specied identier expression and applies the accumulator
expression(s), if specied, to each group. Consumes all input documents and outputs one
document per each distinct group. The output documents only contain the identier eld and, if
specied, accumulated elds.
$limit
(page 463)
Passes the rst n documents unmodied to the pipeline where n is the specied limit. For each
input document, outputs either one document (for the rst n documents) or zero documents (after
the rst n documents).
$match
(page 464)
Filters the document stream to allow only matching documents to pass unmodied into the next
pipeline stage. $match (page 464) uses standard MongoDB queries. For each input document,
outputs either one document (a match) or zero documents (no match).
$out
(page 465)
Writes the resulting documents of the aggregation pipeline to a collection. To use the $out
(page 465) stage, it must be the last stage in the pipeline.
$project
(page 466)
Reshapes each document in the stream, such as by adding new elds or removing existing elds.
For each input document, outputs one document.
$redact
(page 469)
Reshapes each document in the stream by restricting the content for each document based on
information stored in the documents themselves. Incorporates the functionality of $project
(page 466) and $match (page 464). Can be used to implement eld level redaction. For each
input document, outputs either one or zero document.
$skip
(page 473)
Skips the rst n documents where n is the specied skip number and passes the remaining
documents unmodied to the pipeline. For each input document, outputs either zero documents
(for the rst n documents) or one document (if after the rst n documents).
$sort
(page 473)
Reorders the document stream by a specied sort key. Only the order changes; the documents
remain unmodied. For each input document, outputs one document.
$unwind
(page 475)
Deconstructs an array eld from the input documents to output a document for each element.
Each output document replaces the array with an element value. For each input document,
outputs n documents where n is the number of array elements and can be zero for an empty array.
Expressions
Expressions can include eld paths and system variables (page 537), literals (page 538), expression objects (page 538),
and expression operators (page 538). Expressions can be nested.
Field Path and System Variables
Aggregation expressions use eld path to access elds in the input documents. To specify a eld path, use a string that
prexes with a dollar sign $ the eld name or the dotted eld name, if the eld is in embedded document. For example,
"$user" to specify the eld path for the user eld or "$user.name" to specify the eld path to "user.name"
eld.
"$<field>" is equivalent to "$$CURRENT.<field>" where the CURRENT (page 546) is a system variable that
defaults to the root of the current object in the most stages, unless stated otherwise in specic stages. CURRENT
(page 546) can be rebound.
Along with the CURRENT (page 546) system variable, other system variables (page 545) are also available for use
in expressions. To use user-dened variables, use $let (page 505) and $map (page 506) expressions. To access
variables in expressions, use a string that prexes the variable name with $$.
2.4. Aggregation Reference 537
MongoDB Reference Manual, Release 2.6.4
Literals
Literals can be of any type. However, MongoDB parses string literals that start with a dollar sign $ as a path to a eld
and numeric/boolean literals in expression objects (page 538) as projection ags. To avoid parsing literals, use the
$literal (page 507) expression.
Expression Objects
Expression objects have the following form:
{ <field1>: <expression1>, ... }
If the expressions are numeric or boolean literals, MongoDB treats the literals as projection ags (e.g. 1 or true
to include the eld), valid only in the $project (page 466) stage. To avoid treating numeric or boolean literals as
projection ags, use the $literal (page 507) expression to wrap the numeric or boolean literals.
Operator Expressions
Operator expressions are similar to functions that take arguments. In general, these expressions take an array of
arguments and have the following form:
{ <operator>: [ <argument1>, <argument2> ... ] }
If operator accepts a single argument, you can omit the outer array designating the argument list:
{ <operator>: <argument> }
To avoid parsing ambiguity if the argument is a literal array, you must wrap the literal array in a $literal (page 507)
expression or keep the outer array that designates the argument list.
Boolean Expressions Boolean expressions evaluates its argument expressions as booleans and return a boolean as
the result.
In addition to the false boolean value, Boolean expression evaluates as false the following: null, 0, and
undefined values. The Boolean expression evaluates all other values as true, including non-zero numeric values
and arrays.
Name Description
$and
(page 477)
Returns true only when all its expressions evaluate to true. Accepts any number of
argument expressions.
$not
(page 478)
Returns the boolean value that is the opposite of its argument expression. Accepts a single
argument expression.
$or
(page 479)
Returns true when any of its expressions evaluates to true. Accepts any number of argument
expressions.
Set Expressions Set expressions performs set operation on arrays, treating arrays as sets. Set expressions ignores
the duplicate entries in each input array and the order of the elements.
If the set operation returns a set, the operation lters out duplicates in the result to output an array that contains only
unique entries. The order of the elements in the output array is unspecied.
If a set contains a nested array element, the set expression does not descend into the nested array but evaluates the
array at top-level.
538 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Name Description
$allElementsTrue
(page 480)
Returns true if no element of a set evaluates to false, otherwise, returns false.
Accepts a single argument expression.
$anyElementTrue
(page 482)
Returns true if any elements of a set evaluate to true; otherwise, returns false.
Accepts a single argument expression.
$setDifference
(page 483)
Returns a set with elements that appear in the rst set but not in the second set; i.e. performs
a relative complement
35
of the second set relative to the rst. Accepts exactly two argument
expressions.
$setEquals
(page 484)
Returns true if the input sets have the same distinct elements. Accepts two or more
argument expressions.
$setIntersection
(page 485)
Returns a set with elements that appear in all of the input sets. Accepts any number of
argument expressions.
$setIsSubset
(page 486)
Returns true if all elements of the rst set appear in the second set, including when the
rst set equals the second set; i.e. not a strict subset
36
. Accepts exactly two argument
expressions.
$setUnion
(page 487)
Returns a set with elements that appear in any of the input sets. Accepts any number of
argument expressions.
Comparison Expressions Comparison expressions return a boolean except for $cmp (page 488) which returns a
number.
The comparison expressions take two argument expressions and compare both value and type, using the specied
BSON comparison order for values of different types.
Name Description
$cmp
(page 488)
Returns: 0 if the two values are equivalent, 1 if the rst value is greater than the second, and -1 if
the rst value is less than the second.
$eq
(page 489)
Returns true if the values are equivalent.
$gt
(page 490)
Returns true if the rst value is greater than the second.
$gte
(page 491)
Returns true if the rst value is greater than or equal to the second.
$lt
(page 492)
Returns true if the rst value is less than the second.
$lte
(page 493)
Returns true if the rst value is less than or equal to the second.
$ne
(page 493)
Returns true if the values are not equivalent.
Arithmetic Expressions Arithmetic expressions perform mathematic operations on numbers. Some arithmetic ex-
pressions can also support date arithmetic.
33
http://en.wikipedia.org/wiki/Complement_(set_theory)
34
http://en.wikipedia.org/wiki/Subset
35
http://en.wikipedia.org/wiki/Complement_(set_theory)
36
http://en.wikipedia.org/wiki/Subset
2.4. Aggregation Reference 539
MongoDB Reference Manual, Release 2.6.4
Name Description
$add
(page 495)
Adds numbers to return the sum, or adds numbers and a date to return a new date. If adding
numbers and a date, treats the numbers as milliseconds. Accepts any number of argument
expressions, but at most, one expression can resolve to a date.
$divide
(page 496)
Returns the result of dividing the rst number by the second. Accepts two argument expressions.
$mod
(page 496)
Returns the remainder of the rst number divided by the second. Accepts two argument
expressions.
$multiply
(page 497)
Multiplies numbers to return the product. Accepts any number of argument expressions.
$subtract
(page 497)
Returns the result of subtracting the second value from the rst. If the two values are numbers,
return the difference. If the two values are dates, return the difference in milliseconds. If the two
values are a date and a number in milliseconds, return the resulting date. Accepts two argument
expressions. If the two values are a date and a number, specify the date argument rst as it is not
meaningful to subtract a date from a number.
String Expressions String expressions, with the exception of $concat (page 499), only have a well-dened be-
havior for strings of ASCII characters.
$concat (page 499) behavior is well-dened regardless of the characters used.
Name Description
$concat
(page 499)
Concatenates any number of strings.
$strcasecmp
(page 499)
Performs case-insensitive string comparison and returns: 0 if two strings are equivalent, 1 if
the rst string is greater than the second, and -1 if the rst string is less than the second.
$substr
(page 500)
Returns a substring of a string, starting at a specied index position up to a specied length.
Accepts three expressions as arguments: the rst argument must resolve to a string, and the
second and third arguments must resolve to integers.
$toLower
(page 501)
Converts a string to lowercase. Accepts a single argument expression.
$toUpper
(page 502)
Converts a string to uppercase. Accepts a single argument expression.
Text Search Expressions
Name Description
$meta (page 503) Access text search metadata.
Array Expressions
Name Description
$size (page 504) Returns the number of elements in the array. Accepts a single expression as argument.
Variable Expressions
Name Description
$let
(page 505)
Denes variables for use within the scope of a subexpression and returns the result of the
subexpression. Accepts named parameters.
$map
(page 506)
Applies a subexpression to each element of an array and returns the array of resulting values in
order. Accepts named parameters.
Literal Expressions
Name Description
$literal
(page 507)
Return a value without parsing. Use for values that the aggregation pipeline may interpret as an
expression. For example, use a $literal (page 507) expression to a string that starts with a $
to avoid parsing as a eld path.
540 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
Date Expressions
Name Description
$dayOfMonth
(page 509)
Returns the day of the month for a date as a number between 1 and 31.
$dayOfWeek
(page 510)
Returns the day of the week for a date as a number between 1 (Sunday) and 7 (Saturday).
$dayOfYear
(page 511)
Returns the day of the year for a date as a number between 1 and 366 (leap year).
$hour (page 512) Returns the hour for a date as a number between 0 and 23.
$millisecond
(page 513)
Returns the milliseconds of a date as a number between 0 and 999.
$minute
(page 514)
Returns the minute for a date as a number between 0 and 59.
$month
(page 515)
Returns the month for a date as a number between 1 (January) and 12 (December).
$second
(page 515)
Returns the seconds for a date as a number between 0 and 60 (leap seconds).
$week (page 516) Returns the week number for a date as a number between 0 (the partial week that precedes
the rst Sunday of the year) and 53 (leap year).
$year (page 517) Returns the year for a date as a number (e.g. 2014).
Conditional Expressions
Name Description
$cond
(page 518)
A ternary operator that evaluates one expression, and depending on the result, returns the value of
one of the other two expressions. Accepts either three expressions in an ordered list or three
named parameters.
$ifNull
(page 520)
Returns either the non-null result of the rst expression or the result of the second expression if
the rst expression results in a null result. Null result encompasses instances of undened values
or missing elds. Accepts two expressions as arguments. The result of the second expression can
be null.
Accumulators
Accumulators, available only for the $group (page 460) stage, compute values by combining documents that share
the same group key. Accumulators take as input a single expression, evaluating the expression once for each input
document, and maintain their state for the group of documents.
Name Description
$addToSet
(page 521)
Returns an array of unique expression values for each group. Order of the array elements is
undened.
$avg (page 522) Returns an average for each group. Ignores non-numeric values.
$first
(page 522)
Returns a value from the rst document for each group. Order is only dened if the
documents are in a dened order.
$last (page 523) Returns a value from the last document for each group. Order is only dened if the
documents are in a dened order.
$max (page 524) Returns the highest expression value for each group.
$min (page 525) Returns the lowest expression value for each group.
$push (page 526) Returns an array of expression values for each group.
$sum (page 527) Returns a sum for each group. Ignores non-numeric values.
2.4.2 Aggregation Commands Comparison
The following table provides a brief overview of the features of the MongoDB aggregation commands.
2.4. Aggregation Reference 541
MongoDB Reference Manual, Release 2.6.4
aggregate (page 208) mapReduce (page 218) group (page 214)
De-
scrip-
tion
New in version 2.2.
Designed with specic goals of
improving performance and
usability for aggregation tasks.
Uses a pipeline approach
where objects are transformed as
they pass through a series of
pipeline operators such as
$group (page 460), $match
(page 464), and $sort
(page 473).
See Aggregation Pipeline
Operators (page 456) for more
information on the pipeline
operators.
Implements the Map-Reduce
aggregation for processing large
data sets.
Provides grouping functionality.
Is slower than the aggregate
(page 208) command and has less
functionality than the
mapReduce (page 218)
command.
Key
Fea-
tures
Pipeline operators can be
repeated as needed.
Pipeline operators need not
produce one output document for
every input document.
Can also generate new
documents or lter out
documents.
In addition to grouping
operations, can perform complex
aggregation tasks as well as
perform incremental aggregation
on continuously growing
datasets.
See
http://docs.mongodb.org/manualtutorial/map-reduce-examples/
and
http://docs.mongodb.org/manualtutorial/perform-incremental-map-reduce/.
Can either group by existing
elds or with a custom keyf
JavaScript function, can group by
calculated elds.
See group (page 214) for
information and example using
the keyf function.
Flex-
i-
bil-
ity
Limited to the operators and
expressions supported by the
aggregation pipeline.
However, can add computed
elds, create new virtual
sub-objects, and extract
sub-elds into the top-level of
results by using the $project
(page 466) pipeline operator.
See $project (page 466) for
more information as well as
Aggregation Pipeline Operators
(page 456) for more information
on all the available pipeline
operators.
Custom map, reduce and
finalize JavaScript functions
offer exibility to aggregation
logic.
See mapReduce (page 218) for
details and restrictions on the
functions.
Custom reduce and
finalize JavaScript functions
offer exibility to grouping logic.
See group (page 214) for details
and restrictions on these
functions.
Out-
put
Re-
sults
Returns results in various options
(inline as a document that
contains the result set, a cursor to
the result set) or stores the results
in a collection.
The result is subject to the BSON
Document size (page 658) limit if
returned inline as a document
that contains the result set.
Changed in version 2.6: Can
return results as a cursor or store
the results to a collection.
Returns results in various options
(inline, new collection, merge,
replace, reduce). See
mapReduce (page 218) for
details on the output options.
Changed in version 2.2: Provides
much better support for sharded
map-reduce output than previous
versions.
Returns results inline as an array
of grouped items.
The result set must t within the
maximum BSON document size
limit (page 658).
Changed in version 2.2: The
returned array can contain at
most 20,000 elements; i.e. at
most 20,000 unique groupings.
Previous versions had a limit of
10,000 elements.
Shard-
ing
Supports non-sharded and
sharded input collections.
Supports non-sharded and
sharded input collections.
Does not support sharded
collection.
Notes Prior to 2.4, JavaScript code
executed in a single thread.
Prior to 2.4, JavaScript code
executed in a single thread.
More
In-
for-
ma-
tion
See
http://docs.mongodb.org/manualcore/aggregation-pipeline
and aggregate (page 208).
See
http://docs.mongodb.org/manualcore/map-reduce
and mapReduce (page 218).
See group (page 214).
542 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
2.4.3 SQL to Aggregation Mapping Chart
The aggregation pipeline allows MongoDB to provide native aggregation capabilities that corresponds to
many common data aggregation operations in SQL.
The following table provides an overview of common SQL aggregation terms, functions, and concepts and the corre-
sponding MongoDB aggregation operators (page 456):
SQL Terms,
Functions, and
Concepts
MongoDB Aggregation Operators
WHERE $match (page 464)
GROUP BY $group (page 460)
HAVING $match (page 464)
SELECT $project (page 466)
ORDER BY $sort (page 473)
LIMIT $limit (page 463)
SUM() $sum (page 527)
COUNT() $sum (page 527)
join No direct corresponding operator; however, the $unwind (page 475) operator allows
for somewhat similar functionality, but with elds embedded within the document.
Examples
The following table presents a quick reference of SQL aggregation statements and the corresponding MongoDB state-
ments. The examples in the table assume the following conditions:
The SQL examples assume two tables, orders and order_lineitem that join by the
order_lineitem.order_id and the orders.id columns.
The MongoDB examples assume one collection orders that contain documents of the following prototype:
{
cust_id: "abc123",
ord_date: ISODate("2012-11-02T17:04:11.102Z"),
status: 'A',
price: 50,
items: [ { sku: "xxx", qty: 25, price: 1 },
{ sku: "yyy", qty: 25, price: 1 } ]
}
2.4. Aggregation Reference 543
MongoDB Reference Manual, Release 2.6.4
SQL Example MongoDB Example Description
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 price eld from orders
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 the
price eld.
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 the
price eld, 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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
},
total: { $sum: "$price" }
}
}
] )
For each unique cust_id,
ord_date grouping, sum the
price eld. 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_id with multiple records,
return the cust_id and the corre-
sponding 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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
},
total: { $sum: "$price" }
}
},
{ $match: { total: { $gt: 250 } } }
] )
For each unique cust_id,
ord_date grouping, sum the
price eld 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_id with sta-
tus A, sum the price eld.
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_id with sta-
tus A, sumthe price eld 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 item qty elds
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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
}
}
},
{
$group: {
_id: null,
count: { $sum: 1 }
}
}
] )
Count the number of distinct
cust_id, ord_date groupings.
Excludes the time portion of the date.
544 Chapter 2. Interfaces Reference
MongoDB Reference Manual, Release 2.6.4
2.4.4 Aggregation Interfaces
Aggregation Commands
Name Description
aggregate
(page 208)
Performs aggregation tasks such as group using the aggregation framework.
count (page 211) Counts the number of documents in a collection.
distinct (page 213) Displays the distinct values found for a specied key in a collection.
group (page 214) Groups documents in a collection by the specied key and performs simple
aggregation.
mapReduce
(page 218)
Performs map-reduce aggregation for large data sets.
Aggregation Methods
Name Description
db.collection.aggregate()
(page 22)
Provides access to the aggregation pipeline.
db.collection.group()
(page 47)
Groups documents in a collection by the specied key and performs
simple aggregation.
db.collection.mapReduce()
(page 56)
Performs map-reduce aggregation for large data sets.
2.4.5 Variables in Aggregation Expressions
Aggregation expressions (page 537) can use both user-dened and system variables.
Variables can hold any BSON type data. To access the value of the variable, use a string with the variable name
prexed with double dollar signs ($$).
If the variable references an object, to access a specic eld in the object, use the dot notation; i.e.
"$$<variable>.<field>".
User Variables
User variable names can contain the ascii characters [_a-zA-Z0-9] and any non-ascii character.
User variable names must begin with a lowercase ascii letter [a-z] or a non-ascii character.
System Variables
MongoDB offers the following system variables:
2.4. Aggregation Reference 545
MongoDB Reference Manual, Release 2.6.4
Variable Description
ROOT
References the root document, i.e. the top-level doc-
ument, currently being processed in the aggregation
pipeline stage.
CURRENT
References the start of the eld path being processed in
the aggregation pipeline stage. Unless documented oth-
erwise, all stages start with CURRENT (page 546) the
same as ROOT (page 546).
CURRENT (page 546) is modiable. However, since
$<field> is equivalent to $$CURRENT.<field>,
rebinding CURRENT (page 546) changes the meaning
of $ accesses.
DESCEND
One of the allowed results of a $redact (page 469)
expression.
PRUNE
One of the allowed results of a $redact (page 469)
expression.
KEEP
One of the allowed results of a $redact (page 469)
expression.
See also:
$let (page 505), $redact (page 469)
546 Chapter 2. Interfaces Reference
CHAPTER 3
MongoDB and SQL Interface Comparisons
3.1 SQL to MongoDB Mapping Chart
In addition to the charts that follow, you might want to consider the http://docs.mongodb.org/manualfaq
section for a selection of common questions about MongoDB.
3.1.1 Terminology and Concepts
The following table presents the various SQL terminology and concepts and the corresponding MongoDB terminology
and concepts.
SQL Terms/Concepts MongoDB Terms/Concepts
database database
table collection
row document or BSON document
column eld
index index
table joins embedded documents and linking
primary key
Specify any unique column or column combination as
primary key.
primary key
In MongoDB, the primary key is automatically set to
the _id eld.
aggregation (e.g. group by) aggregation pipeline
See the SQL to Aggregation Mapping Chart
(page 552).
3.1.2 Executables
The following table presents some database executables and the corresponding MongoDB executables. This table is
not meant to be exhaustive.
MongoDB MySQL Oracle Informix DB2
Database Server mongod (page 555) mysqld oracle IDS DB2 Server
Database Client mongo (page 580) mysql sqlplus DB-Access DB2 Client
3.1.3 Examples
The following table presents the various SQL statements and the corresponding MongoDB statements. The examples
in the table assume the following conditions:
547
MongoDB Reference Manual, Release 2.6.4
The SQL examples assume a table named users.
The MongoDB examples assume a collection named users that contain documents of the following prototype:
{
_id: ObjectId("509a8fb2f3f4948bd2f983a0"),
user_id: "abc123",
age: 55,
status: 'A'
}
Create and Alter
The following table presents the various SQL statements related to table-level actions and the corresponding MongoDB
statements.
548 Chapter 3. MongoDB and SQL Interface Comparisons
MongoDB Reference Manual, Release 2.6.4
SQL Schema Statements MongoDB Schema Statements
CREATE TABLE users (
id MEDIUMINT NOT NULL
AUTO_INCREMENT,
user_id Varchar(30),
age Number,
status char(1),
PRIMARY KEY (id)
)
Implicitly created on rst insert() (page 53) oper-
ation. The primary key _id is automatically added if
_id eld is not specied.
db.users.insert( {
user_id: "abc123",
age: 55,
status: "A"
} )
However, you can also explicitly create a collection:
db.createCollection("users")
ALTER TABLE users
ADD join_date DATETIME
Collections do not describe or enforce the structure of
its documents; i.e. there is no structural alteration at the
collection level.
However, at the document level, update() (page 70)
operations can add elds to existing documents using
the $set (page 436) operator.
db.users.update(
{ },
{ $set: { join_date: new Date() } },
{ multi: true }
)
ALTER TABLE users
DROP COLUMN join_date
Collections do not describe or enforce the structure of
its documents; i.e. there is no structural alteration at the
collection level.
However, at the document level, update() (page 70)
operations can remove elds from documents using the
$unset (page 436) operator.
db.users.update(
{ },
{ $unset: { join_date: "" } },
{ multi: true }
)
CREATE INDEX idx_user_id_asc
ON users(user_id)
db.users.ensureIndex( { user_id: 1 } )
CREATE INDEX
idx_user_id_asc_age_desc
ON users(user_id, age DESC)
db.users.ensureIndex( { user_id: 1, age: -1 } )
DROP TABLE users db.users.drop()
For more information, see db.collection.insert() (page 53), db.createCollection()
(page 106), db.collection.update() (page 70), $set (page 436), $unset (page 436),
db.collection.ensureIndex() (page 30), indexes, db.collection.drop() (page 28), and
http://docs.mongodb.org/manualcore/data-models.
3.1. SQL to MongoDB Mapping Chart 549
MongoDB Reference Manual, Release 2.6.4
Insert
The following table presents the various SQL statements related to inserting records into tables and the corresponding
MongoDB statements.
SQL INSERT Statements MongoDB insert() Statements
INSERT INTO users(user_id,
age,
status)
VALUES ("bcd001",
45,
"A")
db.users.insert(
{ user_id: "bcd001", age: 45, status: "A" }
)
For more information, see db.collection.insert() (page 53).
Select
The following table presents the various SQL statements related to reading records from tables and the corresponding
MongoDB statements.
550 Chapter 3. MongoDB and SQL Interface Comparisons
MongoDB Reference Manual, Release 2.6.4
SQL SELECT Statements MongoDB nd() Statements
SELECT
*
FROM users
db.users.find()
SELECT id,
user_id,
status
FROM users
db.users.find(
{ },
{ user_id: 1, status: 1 }
)
SELECT user_id, status
FROM users
db.users.find(
{ },
{ user_id: 1, status: 1, _id: 0 }
)
SELECT
*
FROM users
WHERE status = "A"
db.users.find(
{ status: "A" }
)
SELECT user_id, status
FROM users
WHERE status = "A"
db.users.find(
{ status: "A" },
{ user_id: 1, status: 1, _id: 0 }
)
SELECT
*
FROM users
WHERE status != "A"
db.users.find(
{ status: { $ne: "A" } }
)
SELECT
*
FROM users
WHERE status = "A"
AND age = 50
db.users.find(
{ status: "A",
age: 50 }
)
SELECT
*
FROM users
WHERE status = "A"
OR age = 50
db.users.find(
{ $or: [ { status: "A" } ,
{ age: 50 } ] }
)
SELECT
*
FROM users
WHERE age > 25
db.users.find(
{ age: { $gt: 25 } }
)
SELECT
*
FROM users
WHERE age < 25
db.users.find(
{ age: { $lt: 25 } }
)
SELECT
*
FROM users
WHERE age > 25
AND age <= 50
db.users.find(
{ age: { $gt: 25, $lte: 50 } }
)
SELECT
*
FROM users
WHERE user_id like "%bc%"
db.users.find( { user_id: /bc/ } )
SELECT
*
FROM users
WHERE user_id like "bc%"
db.users.find( { user_id: /^bc/ } )
SELECT
*
FROM users
WHERE status = "A"
ORDER BY user_id ASC
db.users.find( { status: "A" } ).sort( { user_id: 1 } )
SELECT
*
FROM users
WHERE status = "A"
ORDER BY user_id DESC
db.users.find( { status: "A" } ).sort( { user_id: -1 } )
SELECT COUNT(
*
)
FROM users
db.users.count()
or
db.users.find().count()
SELECT COUNT(user_id)
FROM users
db.users.count( { user_id: { $exists: true } } )
or
db.users.find( { user_id: { $exists: true } } ).count()
SELECT COUNT(
*
)
FROM users
WHERE age > 30
db.users.count( { age: { $gt: 30 } } )
or
db.users.find( { age: { $gt: 30 } } ).count()
SELECT DISTINCT(status)
FROM users
db.users.distinct( "status" )
SELECT
*
FROM users
LIMIT 1
db.users.findOne()
or
db.users.find().limit(1)
SELECT
*
FROM users
LIMIT 5
SKIP 10
db.users.find().limit(5).skip(10)
EXPLAIN SELECT
*
FROM users
WHERE status = "A"
db.users.find( { status: "A" } ).explain()
3.1. SQL to MongoDB Mapping Chart 551
MongoDB Reference Manual, Release 2.6.4
For more information, see db.collection.find() (page 33), db.collection.distinct() (page 28),
db.collection.findOne() (page 42), $ne (page 389) $and (page 390), $or (page 393), $gt (page 386),
$lt (page 388), $exists (page 395), $lte (page 389), $regex (page 399), limit() (page 89), skip()
(page 95), explain() (page 83), sort() (page 96), and count() (page 81).
Update Records
The following table presents the various SQL statements related to updating existing records in tables and the corre-
sponding MongoDB statements.
SQL Update Statements MongoDB update() Statements
UPDATE users
SET status = "C"
WHERE age > 25
db.users.update(
{ age: { $gt: 25 } },
{ $set: { status: "C" } },
{ multi: true }
)
UPDATE users
SET age = age + 3
WHERE status = "A"
db.users.update(
{ status: "A" } ,
{ $inc: { age: 3 } },
{ multi: true }
)
For more information, see db.collection.update() (page 70), $set (page 436), $inc (page 430), and $gt
(page 386).
Delete Records
The following table presents the various SQL statements related to deleting records from tables and the corresponding
MongoDB statements.
SQL Delete Statements MongoDB remove() Statements
DELETE FROM users
WHERE status = "D"
db.users.remove( { status: "D" } )
DELETE FROM users db.users.remove({})
For more information, see db.collection.remove() (page 64).
3.2 SQL to Aggregation Mapping Chart
The aggregation pipeline allows MongoDB to provide native aggregation capabilities that corresponds to
many common data aggregation operations in SQL.
The following table provides an overview of common SQL aggregation terms, functions, and concepts and the corre-
sponding MongoDB aggregation operators (page 456):
552 Chapter 3. MongoDB and SQL Interface Comparisons
MongoDB Reference Manual, Release 2.6.4
SQL Terms,
Functions, and
Concepts
MongoDB Aggregation Operators
WHERE $match (page 464)
GROUP BY $group (page 460)
HAVING $match (page 464)
SELECT $project (page 466)
ORDER BY $sort (page 473)
LIMIT $limit (page 463)
SUM() $sum (page 527)
COUNT() $sum (page 527)
join No direct corresponding operator; however, the $unwind (page 475) operator allows
for somewhat similar functionality, but with elds embedded within the document.
3.2.1 Examples
The following table presents a quick reference of SQL aggregation statements and the corresponding MongoDB state-
ments. The examples in the table assume the following conditions:
The SQL examples assume two tables, orders and order_lineitem that join by the
order_lineitem.order_id and the orders.id columns.
The MongoDB examples assume one collection orders that contain documents of the following prototype:
{
cust_id: "abc123",
ord_date: ISODate("2012-11-02T17:04:11.102Z"),
status: 'A',
price: 50,
items: [ { sku: "xxx", qty: 25, price: 1 },
{ sku: "yyy", qty: 25, price: 1 } ]
}
3.2. SQL to Aggregation Mapping Chart 553
MongoDB Reference Manual, Release 2.6.4
SQL Example MongoDB Example Description
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 price eld from orders
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 the
price eld.
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 the
price eld, 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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
},
total: { $sum: "$price" }
}
}
] )
For each unique cust_id,
ord_date grouping, sum the
price eld. 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_id with multiple records,
return the cust_id and the corre-
sponding 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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
},
total: { $sum: "$price" }
}
},
{ $match: { total: { $gt: 250 } } }
] )
For each unique cust_id,
ord_date grouping, sum the
price eld 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_id with sta-
tus A, sum the price eld.
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_id with sta-
tus A, sumthe price eld 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 item qty elds
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: {
month: { $month: "$ord_date" },
day: { $dayOfMonth: "$ord_date" },
year: { $year: "$ord_date"}
}
}
}
},
{
$group: {
_id: null,
count: { $sum: 1 }
}
}
] )
Count the number of distinct
cust_id, ord_date groupings.
Excludes the time portion of the date.
554 Chapter 3. MongoDB and SQL Interface Comparisons
CHAPTER 4
Program and Tool Reference Pages
4.1 MongoDB Package Components
4.1.1 Core Processes
The core components in the MongoDB package are: mongod (page 555), the core database process; mongos
(page 571) the controller and query router for sharded clusters; and mongo (page 580) the interactive MongoDB
Shell.
mongod
Synopsis
mongod (page 555) is the primary daemon process for the MongoDB system. It handles data requests, manages data
format, and performs background management operations.
This document provides a complete overview of all command line options for mongod (page 555). These options are
primarily useful for testing purposes. In common operation, use the configuration file options to control
the behavior of your database, which is fully capable of all operations described below.
Options
mongod
Core Options
mongod
command line option!help, -h
--help, -h
Returns information on the options and use of mongod (page 555).
command line option!version
--version
Returns the mongod (page 555) release number.
command line option!cong <lename>, -f
555
MongoDB Reference Manual, Release 2.6.4
--config <filename>, -f
Species a conguration le for runtime conguration options. The conguration le is the preferred method
for runtime conguration of mongod (page 555). The options are equivalent to the command-line congu-
ration options. See http://docs.mongodb.org/manualreference/configuration-options
for more information.
Ensure the conguration le uses ASCII encoding. The mongod (page 555) instance does not support congu-
ration les with non-ASCII encoding, including UTF-8.
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongod (page 555) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!bind_ip <ip address>
--bind_ip <ip address>
Default: All interfaces.
Changed in version 2.6.0: The deb and rpm packages include a default conguration le that sets --bind_ip
(page 572) to 127.0.0.1.
Species the IP address that mongod (page 555) binds to in order to listen for connections from applications.
You may attach mongod (page 555) to any interface. When attaching mongod (page 555) to a publicly acces-
sible interface, ensure that you have implemented proper authentication and rewall restrictions to protect the
integrity of your database.
command line option!maxConns <number>
--maxConns <number>
The maximum number of simultaneous connections that mongod (page 555) will accept. This setting has no
effect if it is higher than your operating systems congured maximum connection tracking threshold.
Changed in version 2.6: MongoDB removed the upward limit on the maxIncomingConnections setting.
command line option!syslog
--syslog
Sends all logging output to the hosts syslog system rather than to standard output or to a log le. , as with
--logpath (page 572).
The --syslog (page 572) option is not supported on Windows.
556 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!syslogFacility <string>
--syslogFacility <string>
Default: user
Species the facility level used when logging messages to syslog. The value you specify must be supported
by your operating systems implementation of syslog. To use this option, you must enable the --syslog
(page 572) option.
command line option!logpath <path>
--logpath <path>
Sends all diagnostic logging information to a log le instead of to standard output or to the hosts syslog system.
MongoDB creates the log le at the path you specify.
By default, MongoDB overwrites the log le when the process restarts. To instead append to the log le, set the
--logappend (page 572) option.
command line option!logappend
--logappend
Appends new entries to the end of the log le rather than overwriting the content of the log when the mongod
(page 555) instance restarts.
command line option!timeStampFormat <string>
--timeStampFormat <string>
Default: iso8601-local
The time format for timestamps in log messages. Specify one of the following values:
Value Description
ctime Displays timestamps as Wed Dec 31 18:17:54.811.
iso8601-utc Displays timestamps in Coordinated Universal Time (UTC) in the ISO-8601 format. For
example, for New York at the start of the Epoch: 1970-01-01T00:00:00.000Z
iso8601-local Displays timestamps in local time in the ISO-8601 format. For example, for New York at the
start of the Epoch: 1969-12-31T19:00:00.000+0500
command line option!diaglog <value>
--diaglog <value>
Default: 0
Deprecated since version 2.6.
--diaglog (page 557) is for internal use and not intended for most users.
Creates a very verbose diagnostic log for troubleshooting and recording various errors. MongoDB writes these
log les in the dbPath directory in a series of les that begin with the string diaglog and end with the
initiation time of the logging as a hex string.
The specied value congures the level of verbosity:
Value Setting
0 Off. No logging.
1 Log write operations.
2 Log read operations.
3 Log both read and write operations.
7 Log write and some read operations.
You can use the mongosniff (page 635) tool to replay this output for investigation. Given a typical diaglog
le located at /data/db/diaglog.4f76a58c, you might use a command in the following form to read
these les:
4.1. MongoDB Package Components 557
MongoDB Reference Manual, Release 2.6.4
mongosniff --source DIAGLOG /data/db/diaglog.4f76a58c
.. warning::
Setting the diagnostic level to ``0`` will cause :program:`mongod`
to stop writing data to the :term:`diagnostic log` file. However,
the :program:`mongod` instance will continue to keep the file open,
even if it is no longer writing data to the file. If you want to
rename, move, or delete the diagnostic log you must cleanly shut
down the :program:`mongod` instance before doing so.
command line option!traceExceptions
--traceExceptions
For internal diagnostic use only.
command line option!pidlepath <path>
--pidfilepath <path>
Species a le location to hold the process ID of the mongod (page 555) process. This is useful for tracking
the mongod (page 555) process in combination with the --fork (page 574) option. Without a specied
--pidfilepath (page 573) option, the process creates no PID le.
command line option!keyFile <le>
--keyFile <file>
Species the path to a key le to that stores the shared secret that MongoDB instances use to authenticate to
each other in a sharded cluster or replica set. --keyFile (page 573) implies --auth (page 559). See
inter-process-auth for more information.
command line option!setParameter <options>
--setParameter <options>
Species one of the MongoDBparameters described in http://docs.mongodb.org/manualreference/parameters.
You can specify multiple setParameter elds.
command line option!httpinterface
--httpinterface
New in version 2.6.
Enables the HTTP interface. Enabling the interface can increase network exposure.
Leave the HTTP interface disabled for production deployments. If you do enable this interface, you should only
allow trusted clients to access this port. See security-rewalls.
Note: In MongoDB Enterprise, the HTTP Console does not support Kerberos Authentication.
command line option!nohttpinterface
--nohttpinterface
Deprecated since version 2.6: MongoDB disables the HTTP interface by default.
Disables the HTTP interface.
Do not use in conjunction with --rest (page 560) or --jsonp (page 579).
Note: In MongoDB Enterprise, the HTTP Console does not support Kerberos Authentication.
command line option!nounixsocket
558 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--nounixsocket
Disables listening on the UNIX domain socket. The mongod (page 555) process always listens on the UNIX
socket unless one of the following is true:
--nounixsocket (page 573) is set
bindIp is not set
bindIp does not specify 127.0.0.1
New in version 2.6: mongod (page 555) installed from ofcial .deb and .rpm packages have the bind_ip
conguration set to 127.0.0.1 by default.
command line option!unixSocketPrex <path>
--unixSocketPrefix <path>
Default: /tmp
The path for the UNIX socket. If this option has no value, the mongod (page 555) process creates a socket with
http://docs.mongodb.org/manualtmp as a prex. MongoDB creates and listens on a UNIX socket
unless one of the following is true:
--nounixsocket (page 573) is set
bindIp is not set
bindIp does not specify 127.0.0.1
command line option!fork
--fork
Enables a daemon mode that runs the mongod (page 555) process in the background. By default mongod
(page 555) does not run as a daemon: typically you will run mongod (page 555) as a daemon, either by using
--fork (page 574) or by using a controlling process that handles the daemonization process (e.g. as with
upstart and systemd).
command line option!auth
--auth
Enables authorization to control users access to database resources and operations. When authorization is
enabled, MongoDB requires all clients to authenticate themselves rst in order to determine the access for the
client.
Congure users via the mongo shell (page 580). If no users exist, the localhost interface will continue to have
access to the database until you create the rst user.
See Security for more information.
command line option!noauth
--noauth
Disables authentication. Currently the default. Exists for future compatibility and clarity.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongod (page 555) to connect to the MongoDB instance using an IPv6
network. All MongoDB programs and processes disable IPv6 support by default.
command line option!jsonp
--jsonp
Permits JSONP access via an HTTP interface. Enabling the interface can increase network exposure. The
--jsonp (page 579) option enables the HTTP interface, even if the HTTP interface option is disabled.
4.1. MongoDB Package Components 559
MongoDB Reference Manual, Release 2.6.4
command line option!rest
--rest
Enables the simple REST API. Enabling the REST API enables the HTTP interface, even if the HTTP
interface option is disabled, and as a result can increase network exposure.
command line option!slowms <value>
--slowms <value>
Default: 100
The threshold in milliseconds at which the database proler considers a query slow. MongoDB records all
slow queries to the log, even when the database proler is off. When the proler is on, it writes to the
system.profile collection. See the profile (page 353) command for more information on the database
proler.
command line option!prole <level>
--profile <level>
Default: 0
Changes the level of database proling, which inserts information about operation performance into standard
output or a log le. Specify one of the following levels:
Level Setting
0 Off. No proling.
1 On. Only includes slow operations.
2 On. Includes all operations.
Database proling can impact database performance. Enable this option only after careful consideration.
command line option!cpu
--cpu
Forces the mongod (page 555) process to report the percentage of CPUtime in write lock. The process generates
output every four seconds and writes the data to standard output or, if you are using the systemLog.path
option, to the log le.
command line option!sysinfo
--sysinfo
Returns diagnostic system information and then exits. The information provides the page size, the number of
physical pages, and the number of available physical pages.
command line option!dbpath <path>
--dbpath <path>
Default: /data/db on Linux and OS X, \data\db on Windows
The directory where the mongod (page 555) instance stores its data. If you installed MongoDB using a package
management system, check the /etc/mongodb.conf le provided by your packages to see which directory
is specied.
command line option!directoryperdb
--directoryperdb
Stores each databases les in its own folder in the data directory. When applied to an existing system, the
directoryPerDB option alters the storage pattern of the data directory.
Use this option in conjunction with your le system and device conguration so that MongoDB will store data
on a number of distinct disk devices to increase write throughput or disk capacity.
560 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Warning: To enable this option for an existing system, migrate the database-specic data les to the new
directory structure before enabling directoryPerDB. Database-specic data les begin with the name
of an existing database and end with either ns or a number. For example, the following data directory
includes les for the local and test databases:
journal
mongod.lock
local.0
local.1
local.ns
test.0
test.1
test.ns
After migration, the data directory would have the following structure:
journal
mongod.lock
local/local.0
local/local.1
local/local.ns
test/test.0
test/test.1
test/test.ns
command line option!noIndexBuildRetry
--noIndexBuildRetry
Stops the mongod (page 555) from rebuilding incomplete indexes on the next start up. This applies in cases
where the mongod (page 555) restarts after it has shut down or stopped in the middle of an index build. In
such cases, the mongod (page 555) always removes any incomplete indexes, and then also, by default, attempts
to rebuild them. To stop the mongod (page 555) from rebuilding incomplete indexes on start up, include this
option on the command-line.
command line option!noprealloc
--noprealloc
Disables the preallocation of data les. This shortens the start up time in some cases and can cause signicant
performance penalties during normal operations.
command line option!nssize <value>
--nssize <value>
Default: 16
Species the default size for namespace les, which are les that end in .ns. Each collection and index counts
as a namespace.
Use this setting to control size for newly created namespace les. This option has no impact on existing les.
The maximum size for a namespace le is 2047 megabytes. The default value of 16 megabytes provides for
approximately 24,000 namespaces.
command line option!quota
--quota
Enables a maximum limit for the number data les each database can have. When running with the
--quota (page 561) option, MongoDB has a maximum of 8 data les per database. Adjust the quota with
--quotaFiles (page 561).
command line option!quotaFiles <number>
4.1. MongoDB Package Components 561
MongoDB Reference Manual, Release 2.6.4
--quotaFiles <number>
Default: 8
Modies the limit on the number of data les per database. --quotaFiles (page 561) option requires that
you set --quota (page 561).
command line option!smallles
--smallfiles
Sets MongoDB to use a smaller default le size. The --smallfiles (page 562) option reduces the initial
size for data les and limits the maximum size to 512 megabytes. --smallfiles (page 562) also reduces
the size of each journal le from 1 gigabyte to 128 megabytes. Use --smallfiles (page 562) if you have a
large number of databases that each holds a small quantity of data.
The --smallfiles (page 562) option can lead the mongod (page 555) instance to create a large number of
les, which can affect performance for larger databases.
command line option!syncdelay <value>
--syncdelay <value>
Default: 60
Controls how much time can pass before MongoDB ushes data to the data les via an fsync operation. Do not
set this value on production systems. In almost every situation, you should use the default setting.
Warning: If you set --syncdelay (page 562) to 0, MongoDB will not sync the memory mapped les
to disk.
The mongod (page 555) process writes data very quickly to the journal and lazily to the data les.
syncPeriodSecs has no effect on the journal les or journaling.
The serverStatus (page 354) command reports the background ush threads status via the
backgroundFlushing (page 360) eld.
command line option!upgrade
--upgrade
Upgrades the on-disk data format of the les specied by the --dbpath (page 600) to the latest version, if
needed.
This option only affects the operation of the mongod (page 555) if the data les are in an old format.
In most cases you should not set this value, so you can exercise the most control over your upgrade process. See
the MongoDB release notes
1
(on the download page) for more information about the upgrade process.
command line option!repair
--repair
Runs a repair routine on all databases. This is equivalent to shutting down and running the repairDatabase
(page 332) database command on all databases.
Warning: During normal operations, only use the repairDatabase (page 332) command and wrappers
including db.repairDatabase() (page 123) in the mongo (page 580) shell and mongod --repair,
to compact database les and/or reclaim disk space. Be aware that these operations remove and do not save
any corrupt data during the repair process.
If you are trying to repair a replica set member, and you have access to an intact copy of your data (e.g. a
recent backup or an intact member of the replica set), you should restore from that intact copy, and not use
repairDatabase (page 332).
1
http://www.mongodb.org/downloads
562 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
When using journaling, there is almost never any need to run repairDatabase (page 332). In the event of
an unclean shutdown, the server will be able to restore the data les to a pristine state automatically.
Changed in version 2.1.2.
If you run the repair option and have data in a journal le, the mongod (page 555) instance refuses to start. In
these cases you should start the mongod (page 555) without the --repair (page 595) option, which allows
the mongod (page 555) to recover data from the journal. This completes more quickly and is more likely
to produce valid data les. To continue the repair operation despite the journal les, shut down the mongod
(page 555) cleanly and restart with the --repair (page 595) option.
The --repair (page 595) option copies data from the source data les into new data les in the repairPath
and then replaces the original data les with the repaired data les. If repairPath is on the same device as
dbPath, you may interrupt a mongod (page 555) running the --repair (page 595) option without affecting
the integrity of the data set.
command line option!repairpath <path>
--repairpath <path>
Default: A _tmp directory within the path specied by the dbPath option.
Species the root directory containing MongoDB data les to use for the --repair (page 595) operation.
command line option!objcheck
--objcheck
Forces the mongod (page 555) to validate all requests fromclients upon receipt to ensure that clients never insert
invalid documents into the database. For objects with a high degree of sub-document nesting, the --objcheck
(page 636) option can have a small impact on performance. You can set --noobjcheck (page 601) to disable
object checking at runtime.
Changed in version 2.4: MongoDB enables the --objcheck (page 636) option by default in order to prevent
any client from inserting malformed or invalid BSON into a MongoDB database.
command line option!noobjcheck
--noobjcheck
New in version 2.4.
Disables the default document validation that MongoDB performs on all incoming BSON documents.
command line option!noscripting
--noscripting
Disables the scripting engine.
command line option!notablescan
--notablescan
Forbids operations that require a table scan. See notablescan for additional information.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongod (page 555) enables journaling by default on 64-bit
builds of versions after 2.0.
command line option!nojournal
--nojournal
Disables the durability journaling. The mongod (page 555) instance enables journaling by default in 64-bit
versions after v2.0.
4.1. MongoDB Package Components 563
MongoDB Reference Manual, Release 2.6.4
command line option!journalOptions <arguments>
--journalOptions <arguments>
Provides functionality for testing. Not for general use, and will affect data le integrity in the case of abnormal
system shutdown.
command line option!journalCommitInterval <value>
--journalCommitInterval <value>
Default: 100 or 30
The maximum amount of time the mongod (page 555) process allows between journal operations. Values can
range from 2 to 300 milliseconds. Lower values increase the durability of the journal, at the expense of disk
performance.
The default journal commit interval is 100 milliseconds if a single block device (e.g. physical volume, RAID
device, or LVM volume) contains both the journal and the data les.
If the journal is on a different block device than the data les the default journal commit interval is 30 millisec-
onds.
To force mongod (page 555) to commit to the journal more frequently, you can specify j:true. When a write
operation with j:true is pending, mongod (page 555) will reduce commitIntervalMs to a third of the
set value.
command line option!shutdown
--shutdown
The --shutdown (page 564) option cleanly and safely terminates the mongod (page 555) process. When
invoking mongod (page 555) with this option you must set the --dbpath (page 600) option either directly or
by way of the configuration file and the --config (page 571) option.
The --shutdown (page 564) option is available only on Linux systems.
Replication Options command line option!replSet <setname>
--replSet <setname>
Congures replication. Specify a replica set name as an argument to this set. All hosts in the replica set must
have the same set name.
If your application connects to more than one replica set, each set should have a distinct name. Some drivers
group replica set connections by replica set name.
command line option!oplogSize <value>
--oplogSize <value>
Species a maximum size in megabytes for the replication operation log (i.e., the oplog). The mongod
(page 555) process creates an oplog based on the maximum amount of space available. For 64-bit systems,
the oplog is typically 5% of available disk space. Once the mongod (page 555) has created the oplog for the
rst time, changing the --oplogSize (page 564) option will not affect the size of the oplog.
command line option!replIndexPrefetch
--replIndexPrefetch
Default: all
New in version 2.2.
Determines which indexes secondary members of a replica set load into memory before applying operations
from the oplog. By default secondaries load all indexes related to an operation into memory before applying
operations from the oplog. This option can have one of the following values:
564 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Value Description
none Secondaries do not load indexes into memory.
all Secondaries load all indexes related to an operation.
_id_only Secondaries load no additional indexes into memory beyond the already existing _id index.
Master-Slave Replication These options provide access to conventional master-slave database replication. While
this functionality remains accessible in MongoDB, replica sets are the preferred conguration for database replication.
command line option!master
--master
Congures the mongod (page 555) to run as a replication master.
command line option!slave
--slave
Congures the mongod (page 555) to run as a replication slave.
command line option!source <host><:port>
--source <host><:port>
For use with the --slave (page 565) option, the --source option designates the server that this instance
will replicate.
command line option!only <arg>
--only <arg>
For use with the --slave (page 565) option, the --only option species only a single database to replicate.
command line option!slavedelay <value>
--slavedelay <value>
For use with the --slave (page 565) option, the --slavedelay (page 565) option congures a delay in
seconds, for this slave to wait to apply operations from the master node.
command line option!autoresync
--autoresync
For use with the --slave (page 565) option. When set, the --autoresync (page 565) option allows this
slave to automatically resync if it is more than 10 seconds behind the master. This setting may be problematic if
the --oplogSize (page 564) species a too small oplog.
If the oplog is not large enough to store the difference in changes between the masters current state and the
state of the slave, this instance will forcibly resync itself unnecessarily. If you dont specify --autoresync
(page 565), the slave will not attempt an automatic resync more than once in a ten minute period.
command line option!fastsync
--fastsync
In the context of replica set replication, set this option if you have seeded this member with an up-to-date copy
of the entire dbPath of another member of the set. Otherwise the mongod (page 555) will attempt to perform
an initial sync, as though the member were a new member.
Warning: If the data is not perfectly synchronized and the mongod (page 555) starts with fastsync,
then the secondary or slave will be permanently out of sync with the primary, which may cause signicant
consistency problems.
Sharded Cluster Options command line option!congsvr
4.1. MongoDB Package Components 565
MongoDB Reference Manual, Release 2.6.4
--configsvr
Declares that this mongod (page 555) instance serves as the cong database of a sharded cluster. When running
with this option, clients will not be able to write data to any database other than config and admin. The
default port for a mongod (page 555) with this option is 27019 and the default --dbpath (page 600) directory
is /data/configdb, unless specied.
Changed in version 2.2: The --configsvr (page 565) option also sets --smallfiles (page 562).
Changed in version 2.4: The --configsvr (page 565) option creates a local oplog.
Do not use the --configsvr (page 565) option with --replSet (page 564) or --shardsvr (page 566).
Cong servers cannot be a shard server or part of a replica set.
command line option!shardsvr
--shardsvr
Congures this mongod (page 555) instance as a shard in a partitioned cluster. The default port for these
instances is 27018. The only effect of --shardsvr (page 566) is to change the port number.
command line option!moveParanoia
--moveParanoia
New in version 2.4.
During chunk migrations, the --moveParanoia (page 566) option forces the mongod (page 555) instances
to save to the moveChunk directory of the storage.dbPath all the documents migrated from this shard.
MongoDB does not delete data stored in moveChunk.
Prior to 2.4, --moveParanoia (page 566) was the default behavior of MongoDB.
SSLOptions
See
http://docs.mongodb.org/manualtutorial/configure-ssl for full documentation of MongoDBs
support.
command line option!sslOnNormalPorts
--sslOnNormalPorts
Deprecated since version 2.6.
Enables SSL for mongod (page 555).
With --sslOnNormalPorts (page 575), a mongod (page 555) requires SSL encryption for all con-
nections on the default MongoDB port, or the port specied by --port (page 631). By default,
--sslOnNormalPorts (page 575) is disabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslMode <mode>
--sslMode <mode>
New in version 2.6.
Enables SSL or mixed SSL on a port. The argument to the --sslMode (page 575) option can be one of the
following:
566 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Value Description
disabled The server does not use SSL.
allowSSL Connections between servers do not use SSL. For incoming connections, the server accepts
both SSL and non-SSL.
preferSSL Connections between servers use SSL. For incoming connections, the server accepts both
SSL and non-SSL.
requireSSLThe server uses and accepts only SSL encrypted connections.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.2.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
When SSL is enabled, you must specify --sslPEMKeyFile (page 631).
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.2.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongod (page 555) will redact the password from all logging and reporting output.
Changed in version 2.6: If the private key in the PEM le is encrypted and you do not specify the
--sslPEMKeyPassword (page 632) option, the mongod (page 555) will prompt for a passphrase. See
ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!clusterAuthMode <option>
--clusterAuthMode <option>
Default: keyFile
New in version 2.6.
The authentication mode used for cluster authentication. If you use internal x.509 authentication, specify so
here. This option can have one of the following values:
Value Description
keyFile Use a keyle for authentication. Accept only keyles.
sendKeyFileFor rolling upgrade purposes. Send a keyle for authentication but can accept both keyles
and x.509 certicates.
sendX509 For rolling upgrade purposes. Send the x.509 certicate for authentication but can accept
both keyles and x.509 certicates.
x509 Recommended. Send the x.509 certicate for authentication and accept only x.509
certicates.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslClusterFile <lename>
4.1. MongoDB Package Components 567
MongoDB Reference Manual, Release 2.6.4
--sslClusterFile <filename>
New in version 2.6.
Species the .pem le that contains the x.509 certicate-key le for membership authentication for the cluster
or replica set.
If --sslClusterFile (page 576) does not specify the .pem le for internal cluster authentication, the
cluster uses the .pem le specied in the --sslPEMKeyFile (page 631) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslClusterPassword <value>
--sslClusterPassword <value>
New in version 2.6.
Species the password to de-crypt the x.509 certicate-key le specied with --sslClusterFile. Use the
--sslClusterPassword (page 577) option only if the certicate-key le is encrypted. In all cases, the
mongod (page 555) will redact the password from all logging and reporting output.
If the x.509 key le is encrypted and you do not specify the --sslClusterPassword (page 577) option,
the mongod (page 555) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.4.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the --sslCAFile option and its target le are not specied, x.509 client and member
authentication will not function. mongod (page 555), and mongos (page 571) in sharded systems, will not
be able to verify the certicates of processes connecting to it against the trusted certicate authority (CA)
that issued them, breaking the certicate chain.
As of version 2.6.4, mongod (page 555) will not start with x.509 authentication enabled if the CA le is not
specied.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.4.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
568 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Bypasses the validation checks for SSL certicates on other servers in the cluster and allows the use of invalid
certicates. When using the allowInvalidCertificates setting, MongoDB logs as a warning the use
of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslWeakCerticateValidation
--sslWeakCertificateValidation
New in version 2.4.
Disables the requirement for SSL certicate validation that --sslCAFile enables. With the
--sslWeakCertificateValidation (page 577) option, the mongod (page 555) will accept connec-
tions when the client does not present a certicate when establishing the connection.
If the client presents a certicate and the mongod (page 555) has --sslWeakCertificateValidation
(page 577) enabled, the mongod (page 555) will validate the certicate using the root certicate chain specied
by --sslCAFile and reject clients with invalid certicates.
Use the --sslWeakCertificateValidation (page 577) option if you have a mixed deployment that
includes clients that do not or cannot present certicates to the mongod (page 555).
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.4.
Directs the mongod (page 555) to use the FIPS mode of the installed OpenSSL library. Your system must have
a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Audit Options command line option!auditDestination
--auditDestination
New in version 2.6.
Enables auditing. The --auditDestination (page 578) option can have one of the following values:
Value Description
syslogOutput the audit events to syslog in JSON format. Not available on Windows. Audit messages
have a syslog severity level of info and a facility level of user.
The syslog message limit can result in the truncation of audit messages. The auditing system will
neither detect the truncation nor error upon its occurrence.
consoleOutput the audit events to stdout in JSON format.
file Output the audit events to the le specied in --auditPath (page 579) in the format specied
in --auditFormat (page 578).
Note: The audit system is available only in MongoDB Enterprise
2
.
command line option!auditFormat
--auditFormat
New in version 2.6.
2
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 569
MongoDB Reference Manual, Release 2.6.4
Species the format of the output le if --auditDestination (page 578) is file. The --auditFormat
(page 578) option can have one of the following values:
Value Description
JSON Output the audit events in JSON format to the le specied in --auditPath (page 579).
BSON Output the audit events in BSON binary format to the le specied in --auditPath (page 579).
Printing audit events to a le in JSON format degrades server performance more than printing to a le in BSON
format.
Note: The audit system is available only in MongoDB Enterprise
3
.
command line option!auditPath
--auditPath
New in version 2.6.
Species the output le for auditing if --auditDestination (page 578) has value of file. The
--auditPath (page 579) option can take either a full path name or a relative path name.
Note: The audit system is available only in MongoDB Enterprise
4
.
command line option!auditFilter
--auditFilter
New in version 2.6.
Species the lter to limit the types of operations the audit system records. The option takes a document of the
form:
{ atype: <expression> }
For authentication operations, the option can also take a document of the form:
{ atype: <expression>, "param.db": <database> }
Note: The audit system is available only in MongoDB Enterprise
5
.
SNMP Options command line option!snmp-subagent
--snmp-subagent
Runs SNMP as a subagent. For more information, see http://docs.mongodb.org/manualtutorial/monitor-with-snmp.
command line option!snmp-master
--snmp-master
Runs SNMP as a master. For more information, see http://docs.mongodb.org/manualtutorial/monitor-with-snmp.
mongos
Synopsis
mongos (page 571) for MongoDB Shard, is a routing service for MongoDB shard congurations that processes
queries from the application layer, and determines the location of this data in the sharded cluster, in order to complete
3
http://www.mongodb.com/products/mongodb-enterprise
4
http://www.mongodb.com/products/mongodb-enterprise
5
http://www.mongodb.com/products/mongodb-enterprise
570 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
these operations. From the perspective of the application, a mongos (page 571) instance behaves identically to any
other MongoDB instance.
Considerations
Never change the name of the mongos (page 571) binary.
Options
mongos
Core Options
mongos
command line option!help, -h
--help, -h
Returns information on the options and use of mongos (page 571).
command line option!version
--version
Returns the mongos (page 571) release number.
command line option!cong <lename>, -f
--config <filename>, -f
Species a conguration le for runtime conguration options. The conguration le is the preferred method
for runtime conguration of mongos (page 571). The options are equivalent to the command-line congu-
ration options. See http://docs.mongodb.org/manualreference/configuration-options
for more information.
Ensure the conguration le uses ASCII encoding. The mongos (page 571) instance does not support congu-
ration les with non-ASCII encoding, including UTF-8.
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongos (page 571) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
4.1. MongoDB Package Components 571
MongoDB Reference Manual, Release 2.6.4
command line option!bind_ip <ip address>
--bind_ip <ip address>
Default: All interfaces.
Changed in version 2.6.0: The deb and rpm packages include a default conguration le that sets --bind_ip
(page 572) to 127.0.0.1.
Species the IP address that mongos (page 571) binds to in order to listen for connections from applications.
You may attach mongos (page 571) to any interface. When attaching mongos (page 571) to a publicly acces-
sible interface, ensure that you have implemented proper authentication and rewall restrictions to protect the
integrity of your database.
command line option!maxConns <number>
--maxConns <number>
Species the maximum number of simultaneous connections that mongos (page 571) will accept. This setting
will have no effect if the value of this setting is higher than your operating systems congured maximum
connection tracking threshold.
This setting is particularly useful for mongos (page 571) if you have a client that creates a num-
ber of connections but allows them to timeout rather than close the connections. When you set
maxIncomingConnections, ensure the value is slightly higher than the size of the connection pool or
the total number of connections to prevent erroneous connection spikes from propagating to the members of a
sharded cluster.
Changed in version 2.6: MongoDB removed the upward limit on the maxIncomingConnections setting.
command line option!syslog
--syslog
Sends all logging output to the hosts syslog system rather than to standard output or to a log le. , as with
--logpath (page 572).
The --syslog (page 572) option is not supported on Windows.
command line option!syslogFacility <string>
--syslogFacility <string>
Default: user
Species the facility level used when logging messages to syslog. The value you specify must be supported
by your operating systems implementation of syslog. To use this option, you must enable the --syslog
(page 572) option.
command line option!logpath <path>
--logpath <path>
Sends all diagnostic logging information to a log le instead of to standard output or to the hosts syslog system.
MongoDB creates the log le at the path you specify.
By default, MongoDB overwrites the log le when the process restarts. To instead append to the log le, set the
--logappend (page 572) option.
command line option!logappend
--logappend
Appends new entries to the end of the log le rather than overwriting the content of the log when the mongos
(page 571) instance restarts.
command line option!timeStampFormat <string>
--timeStampFormat <string>
Default: iso8601-local
572 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
The time format for timestamps in log messages. Specify one of the following values:
Value Description
ctime Displays timestamps as Wed Dec 31 18:17:54.811.
iso8601-utc Displays timestamps in Coordinated Universal Time (UTC) in the ISO-8601 format. For
example, for New York at the start of the Epoch: 1970-01-01T00:00:00.000Z
iso8601-local Displays timestamps in local time in the ISO-8601 format. For example, for New York at the
start of the Epoch: 1969-12-31T19:00:00.000+0500
command line option!pidlepath <path>
--pidfilepath <path>
Species a le location to hold the process ID of the mongos (page 571) process. This is useful for tracking
the mongos (page 571) process in combination with the --fork (page 574) option. Without a specied
--pidfilepath (page 573) option, the process creates no PID le.
command line option!keyFile <le>
--keyFile <file>
Species the path to a key le to that stores the shared secret that MongoDB instances use to authenticate to
each other in a sharded cluster or replica set. --keyFile (page 573) implies --auth (page 559). See
inter-process-auth for more information.
command line option!setParameter <options>
--setParameter <options>
Species one of the MongoDBparameters described in http://docs.mongodb.org/manualreference/parameters.
You can specify multiple setParameter elds.
command line option!httpinterface
--httpinterface
New in version 2.6.
Enables the HTTP interface. Enabling the interface can increase network exposure.
Leave the HTTP interface disabled for production deployments. If you do enable this interface, you should only
allow trusted clients to access this port. See security-rewalls.
Note: In MongoDB Enterprise, the HTTP Console does not support Kerberos Authentication.
command line option!nounixsocket
--nounixsocket
Disables listening on the UNIX domain socket. The mongos (page 571) process always listens on the UNIX
socket unless one of the following is true:
--nounixsocket (page 573) is set
bindIp is not set
bindIp does not specify 127.0.0.1
New in version 2.6: mongos (page 571) installed from ofcial .deb and .rpm packages have the bind_ip
conguration set to 127.0.0.1 by default.
command line option!unixSocketPrex <path>
--unixSocketPrefix <path>
Default: /tmp
4.1. MongoDB Package Components 573
MongoDB Reference Manual, Release 2.6.4
The path for the UNIX socket. If this option has no value, the mongos (page 571) process creates a socket with
http://docs.mongodb.org/manualtmp as a prex. MongoDB creates and listens on a UNIX socket
unless one of the following is true:
--nounixsocket (page 573) is set
bindIp is not set
bindIp does not specify 127.0.0.1
command line option!fork
--fork
Enables a daemon mode that runs the mongos (page 571) process in the background. By default mongos
(page 571) does not run as a daemon: typically you will run mongos (page 571) as a daemon, either by using
--fork (page 574) or by using a controlling process that handles the daemonization process (e.g. as with
upstart and systemd).
Sharded Cluster Options command line option!congdb <cong1>,<cong2>,<cong3>
--configdb <config1>,<config2>,<config3>
Species the conguration database for the sharded cluster. You must specify either 1 or 3 conguration
servers, in a comma separated list.
All mongos (page 571) instances must specify the hosts in the --configdb (page 574) option in the in the
same order.
If your conguration databases reside in more that one data center, order the hosts so that the cong database
that is closest to the majority of your mongos (page 571) instances is rst servers in the list.
Warning: Never remove a cong server from this setting, even if the cong server is not available or
ofine.
command line option!localThreshold
--localThreshold
Default: 15
Affects the logic that mongos (page 571) uses when selecting replica set members to pass read operations to
from clients. Specify a value in milliseconds. The default value of 15 corresponds to the default value in all of
the client drivers.
When mongos (page 571) receives a request that permits reads to secondary members, the mongos (page 571)
will:
Find the member of the set with the lowest ping time.
Construct a list of replica set members that is within a ping time of 15 milliseconds of the nearest suitable
member of the set.
If you specify a value for the --localThreshold (page 574) option, mongos (page 571) will construct
the list of replica members that are within the latency allowed by this value.
Select a member to read from at random from this list.
The ping time used for a member compared by the --localThreshold (page 574) setting is a moving
average of recent ping times, calculated at most every 10 seconds. As a result, some queries may reach members
above the threshold until the mongos (page 571) recalculates the average.
See the replica-set-read-preference-behavior-member-selection section of the read preference documen-
tation for more information.
574 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!upgrade
--upgrade
Updates the meta data format used by the cong database.
command line option!chunkSize <value>
--chunkSize <value>
Default: 64
Determines the size in megabytes of each chunk in the sharded cluster. A size of 64 megabytes is ideal in most
deployments: larger chunk size can lead to uneven data distribution; smaller chunk size can lead to inefcient
movement of chunks between nodes.
This option affects chunk size only when you initialize the cluster for the rst
time. If you later modify the option, the new value has no effect. See the
http://docs.mongodb.org/manualtutorial/modify-chunk-size-in-sharded-cluster
procedure if you need to change the chunk size on an existing sharded cluster.
command line option!noAutoSplit
--noAutoSplit
Prevents mongos (page 571) from automatically inserting metadata splits in a sharded collection. If set on all
mongos (page 571) instances, this prevents MongoDB from creating new chunks as the data in a collection
grows.
Because any mongos (page 571) in a cluster can create a split, to totally disable splitting in a cluster you must
set --noAutoSplit (page 575) on all mongos (page 571).
Warning: With --noAutoSplit (page 575) enabled, the data in your sharded cluster may become
imbalanced over time. Enable with caution.
SSLOptions
See
http://docs.mongodb.org/manualtutorial/configure-ssl for full documentation of MongoDBs
support.
command line option!sslOnNormalPorts
--sslOnNormalPorts
Deprecated since version 2.6.
Enables SSL for mongos (page 571).
With --sslOnNormalPorts (page 575), a mongos (page 571) requires SSL encryption for all con-
nections on the default MongoDB port, or the port specied by --port (page 631). By default,
--sslOnNormalPorts (page 575) is disabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslMode <mode>
--sslMode <mode>
New in version 2.6.
Enables SSL or mixed SSL on a port. The argument to the --sslMode (page 575) option can be one of the
following:
4.1. MongoDB Package Components 575
MongoDB Reference Manual, Release 2.6.4
Value Description
disabled The server does not use SSL.
allowSSL Connections between servers do not use SSL. For incoming connections, the server accepts
both SSL and non-SSL.
preferSSL Connections between servers use SSL. For incoming connections, the server accepts both
SSL and non-SSL.
requireSSLThe server uses and accepts only SSL encrypted connections.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.2.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
When SSL is enabled, you must specify --sslPEMKeyFile (page 631).
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.2.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongos (page 571) will redact the password from all logging and reporting output.
Changed in version 2.6: If the private key in the PEM le is encrypted and you do not specify the
--sslPEMKeyPassword (page 632) option, the mongos (page 571) will prompt for a passphrase. See
ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!clusterAuthMode <option>
--clusterAuthMode <option>
Default: keyFile
New in version 2.6.
The authentication mode used for cluster authentication. If you use internal x.509 authentication, specify so
here. This option can have one of the following values:
Value Description
keyFile Use a keyle for authentication. Accept only keyles.
sendKeyFileFor rolling upgrade purposes. Send a keyle for authentication but can accept both keyles
and x.509 certicates.
sendX509 For rolling upgrade purposes. Send the x.509 certicate for authentication but can accept
both keyles and x.509 certicates.
x509 Recommended. Send the x.509 certicate for authentication and accept only x.509
certicates.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslClusterFile <lename>
576 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--sslClusterFile <filename>
New in version 2.6.
Species the .pem le that contains the x.509 certicate-key le for membership authentication for the cluster
or replica set.
If --sslClusterFile (page 576) does not specify the .pem le for internal cluster authentication, the
cluster uses the .pem le specied in the --sslPEMKeyFile (page 631) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslClusterPassword <value>
--sslClusterPassword <value>
New in version 2.6.
Species the password to de-crypt the x.509 certicate-key le specied with --sslClusterFile. Use the
--sslClusterPassword (page 577) option only if the certicate-key le is encrypted. In all cases, the
mongos (page 571) will redact the password from all logging and reporting output.
If the x.509 key le is encrypted and you do not specify the --sslClusterPassword (page 577) option,
the mongos (page 571) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.4.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the --sslCAFile option and its target le are not specied, x.509 client and member
authentication will not function. mongod (page 555), and mongos (page 571) in sharded systems, will not
be able to verify the certicates of processes connecting to it against the trusted certicate authority (CA)
that issued them, breaking the certicate chain.
As of version 2.6.4, mongod (page 555) will not start with x.509 authentication enabled if the CA le is not
specied.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.4.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslWeakCerticateValidation
--sslWeakCertificateValidation
New in version 2.4.
4.1. MongoDB Package Components 577
MongoDB Reference Manual, Release 2.6.4
Disables the requirement for SSL certicate validation that --sslCAFile enables. With the
--sslWeakCertificateValidation (page 577) option, the mongos (page 571) will accept connec-
tions when the client does not present a certicate when establishing the connection.
If the client presents a certicate and the mongos (page 571) has --sslWeakCertificateValidation
(page 577) enabled, the mongos (page 571) will validate the certicate using the root certicate chain specied
by --sslCAFile and reject clients with invalid certicates.
Use the --sslWeakCertificateValidation (page 577) option if you have a mixed deployment that
includes clients that do not or cannot present certicates to the mongos (page 571).
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for SSL certicates on other servers in the cluster and allows the use of invalid
certicates. When using the allowInvalidCertificates setting, MongoDB logs as a warning the use
of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.4.
Directs the mongos (page 571) to use the FIPS mode of the installed OpenSSL library. Your system must have
a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Audit Options command line option!auditDestination
--auditDestination
New in version 2.6.
Enables auditing. The --auditDestination (page 578) option can have one of the following values:
Value Description
syslogOutput the audit events to syslog in JSON format. Not available on Windows. Audit messages
have a syslog severity level of info and a facility level of user.
The syslog message limit can result in the truncation of audit messages. The auditing system will
neither detect the truncation nor error upon its occurrence.
consoleOutput the audit events to stdout in JSON format.
file Output the audit events to the le specied in --auditPath (page 579) in the format specied
in --auditFormat (page 578).
Note: The audit system is available only in MongoDB Enterprise
6
.
command line option!auditFormat
--auditFormat
New in version 2.6.
6
http://www.mongodb.com/products/mongodb-enterprise
578 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Species the format of the output le if --auditDestination (page 578) is file. The --auditFormat
(page 578) option can have one of the following values:
Value Description
JSON Output the audit events in JSON format to the le specied in --auditPath (page 579).
BSON Output the audit events in BSON binary format to the le specied in --auditPath (page 579).
Printing audit events to a le in JSON format degrades server performance more than printing to a le in BSON
format.
Note: The audit system is available only in MongoDB Enterprise
7
.
command line option!auditPath
--auditPath
New in version 2.6.
Species the output le for auditing if --auditDestination (page 578) has value of file. The
--auditPath (page 579) option can take either a full path name or a relative path name.
Note: The audit system is available only in MongoDB Enterprise
8
.
command line option!auditFilter
--auditFilter
New in version 2.6.
Species the lter to limit the types of operations the audit system records. The option takes a document of the
form:
{ atype: <expression> }
For authentication operations, the option can also take a document of the form:
{ atype: <expression>, "param.db": <database> }
Note: The audit system is available only in MongoDB Enterprise
9
.
Additional Options command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongos (page 571) to connect to the MongoDB instance using an IPv6
network. All MongoDB programs and processes disable IPv6 support by default.
command line option!jsonp
--jsonp
Permits JSONP access via an HTTP interface. Enabling the interface can increase network exposure. The
--jsonp (page 579) option enables the HTTP interface, even if the HTTP interface option is disabled.
command line option!noscripting
--noscripting
Disables the scripting engine.
7
http://www.mongodb.com/products/mongodb-enterprise
8
http://www.mongodb.com/products/mongodb-enterprise
9
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 579
MongoDB Reference Manual, Release 2.6.4
mongo
Description
mongo
mongo (page 580) is an interactive JavaScript shell interface to MongoDB, which provides a powerful interface for
systems administrators as well as a way for developers to test queries and operations directly with the database. mongo
(page 580) also provides a fully functional JavaScript environment for use with a MongoDB. This document addresses
the basic invocation of the mongo (page 580) shell and an overview of its usage.
Options
Core Options
mongo
command line option!shell
--shell
Enables the shell interface. If you invoke the mongo (page 580) command and specify a JavaScript le as an
argument, or use --eval (page 580) to specify JavaScript on the command line, the --shell (page 580)
option provides the user with a shell prompt after the le nishes executing.
command line option!nodb
--nodb
Prevents the shell from connecting to any database instances. Later, to connect to a database within the shell,
see mongo-shell-new-connections.
command line option!norc
--norc
Prevents the shell from sourcing and evaluating ~/.mongorc.js on start up.
command line option!quiet
--quiet
Silences output from the shell during the connection process.
command line option!port <port>
--port <port>
Species the port where the mongod (page 555) or mongos (page 571) instance is listening. If --port
(page 631) is not specied, mongo (page 580) attempts to connect to port 27017.
command line option!host <hostname>
--host <hostname>
Species the name of the host machine where the mongod (page 555) or mongos (page 571) is running. If this
is not specied, mongo (page 580) attempts to connect to a MongoDB process running on the localhost.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
command line option!eval <javascript>
--eval <javascript>
Evaluates a JavaScript expression that is specied as an argument. mongo (page 580) does not load its own
environment when evaluating code. As a result many options of the shell environment are not available.
580 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!help, -h
--help, -h
Returns information on the options and use of mongo (page 580).
command line option!version
--version
Returns the mongo (page 580) release number.
command line option!verbose
--verbose
Increases the verbosity of the output of the shell during the connection process.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongo (page 580) to connect to the MongoDB instance using an IPv6
network. All MongoDB programs and processes disable IPv6 support by default.
<db address>
Species the database address of the database to connect to. For example:
mongo admin
The above command will connect the mongo (page 580) shell to the admin database on the local machine. You
may specify a remote database instance, with the resolvable hostname or IP address. Separate the database name
from the hostname using a http://docs.mongodb.org/manual character. See the following examples:
mongo mongodb1.example.net
mongo mongodb1/admin
mongo 10.8.8.10/test
This syntax is the only way to connect to a specic database.
To specify alternate hosts and a database, you must use this syntax and cannot use --host (page 631) or
--port (page 631).
<file.js>
Species a JavaScript le to run and then exit. Generally this should be the last option specied.
Optional
To specify a JavaScript le to execute and allow mongo (page 580) to prompt you for a password us-
ing --password (page 632), pass the lename as the rst parameter with --username (page 632) and
--password (page 632) as the last options, as in the following:
mongo file.js --username username --password
Use the --shell (page 580) option to return to a shell after the le nishes running.
4.1. MongoDB Package Components 581
MongoDB Reference Manual, Release 2.6.4
Authentication Options command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentication database, the
mongo (page 580) assumes that the database specied as the argument to --authenticationDatabase
(page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongo (page 580) instance uses to authenticate to the mongod
(page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
12
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
13
.
SSL Options command line option!ssl
--ssl
New in version 2.2.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.4.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl option to connect to a mongod (page 555) or mongos (page 571)
that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
10
http://www.mongodb.com/products/mongodb-enterprise
11
http://www.mongodb.com/products/mongodb-enterprise
12
http://www.mongodb.com/products/mongodb-enterprise
13
http://www.mongodb.com/products/mongodb-enterprise
582 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--sslPEMKeyPassword <value>
New in version 2.4.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongo (page 580) will redact the password from all logging and reporting output.
Changed in version 2.6: If the private key in the PEM le is encrypted and you do not specify the
--sslPEMKeyPassword (page 632) option, the mongo (page 580) will prompt for a passphrase. See ssl-
certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.4.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.4.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.4.
Directs the mongo (page 580) to use the FIPS mode of the installed OpenSSL library. Your system must have
a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
4.1. MongoDB Package Components 583
MongoDB Reference Manual, Release 2.6.4
Files
~/.dbshell mongo (page 580) maintains a history of commands in the .dbshell le.
Note: mongo (page 580) does not recorded interaction related to authentication in the history le, including
authenticate (page 261) and db.addUser() (page 148).
Warning: Versions of Windows mongo.exe earlier than 2.2.0 will save the .dbshell le in the
mongo.exe working directory.
~/.mongorc.js mongo (page 580) will read the .mongorc.js le from the home directory of the user invoking
mongo (page 580). In the le, users can dene variables, customize the mongo (page 580) shell prompt, or
update information that they would like updated every time they launch a shell. If you use the shell to evaluate
a JavaScript le or expression either on the command line with --eval (page 580) or by specifying a .js le
to mongo (page 581), mongo (page 580) will read the .mongorc.js le after the JavaScript has nished
processing.
Specify the --norc (page 580) option to disable reading .mongorc.js.
/etc/mongorc.js Global mongorc.js le which the mongo (page 580) shell evaluates upon start-up. If a user
also has a .mongorc.js le located in the HOME (page 584) directory, the mongo (page 580) shell evaluates
the global /etc/mongorc.js le before evaluating the users .mongorc.js le.
/etc/mongorc.js must have read permission for the user running the shell. The --norc (page 580) option
for mongo (page 580) suppresses only the users .mongorc.js le.
On Windows, the global mongorc.js </etc/mongorc.js> exists in the %ProgramData%\MongoDB
directory.
http://docs.mongodb.org/manualtmp/mongo_edit<time_t>.js Created by mongo (page 580)
when editing a le. If the le exists, mongo (page 580) will append an integer from 1 to 10 to the time
value to attempt to create a unique le.
%TEMP%mongo_edit<time_t>.js Created by mongo.exe on Windows when editing a le. If the le exists,
mongo (page 580) will append an integer from 1 to 10 to the time value to attempt to create a unique le.
Environment
EDITOR
Species the path to an editor to use with the edit shell command. A JavaScript variable EDITOR will override
the value of EDITOR (page 584).
HOME
Species the path to the home directory where mongo (page 580) will read the .mongorc.js le and write
the .dbshell le.
HOMEDRIVE
On Windows systems, HOMEDRIVE (page 584) species the path the directory where mongo (page 580) will
read the .mongorc.js le and write the .dbshell le.
HOMEPATH
Species the Windows path to the home directory where mongo (page 580) will read the .mongorc.js le
and write the .dbshell le.
584 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Keyboard Shortcuts
The mongo (page 580) shell supports the following keyboard shortcuts:
14
Keybinding Function
Up arrow Retrieve previous command from history
Down-arrow Retrieve next command from history
Home Go to beginning of the line
End Go to end of the line
Tab Autocomplete method/command
Left-arrow Go backward one character
Right-arrow Go forward one character
Ctrl-left-arrow Go backward one word
Ctrl-right-arrow Go forward one word
Meta-left-arrow Go backward one word
Meta-right-arrow Go forward one word
Ctrl-A Go to the beginning of the line
Ctrl-B Go backward one character
Ctrl-C Exit the mongo (page 580) shell
Ctrl-D Delete a char (or exit the mongo (page 580) shell)
Ctrl-E Go to the end of the line
Ctrl-F Go forward one character
Ctrl-G Abort
Ctrl-J Accept/evaluate the line
Ctrl-K Kill/erase the line
Ctrl-L or type cls Clear the screen
Ctrl-M Accept/evaluate the line
Ctrl-N Retrieve next command from history
Ctrl-P Retrieve previous command from history
Ctrl-R Reverse-search command history
Ctrl-S Forward-search command history
Ctrl-T Transpose characters
Ctrl-U Perform Unix line-discard
Ctrl-W Perform Unix word-rubout
Ctrl-Y Yank
Ctrl-Z Suspend (job control works in linux)
Ctrl-H Backward-delete a character
Ctrl-I Complete, same as Tab
Meta-B Go backward one word
Meta-C Capitalize word
Meta-D Kill word
Meta-F Go forward one word
Meta-L Change word to lowercase
Meta-U Change word to uppercase
Meta-Y Yank-pop
Meta-Backspace Backward-kill word
Meta-< Retrieve the rst command in command history
Meta-> Retrieve the last command in command history
14
MongoDB accommodates multiple keybinding. Since 2.0, mongo (page 580) includes support for basic emacs keybindings.
4.1. MongoDB Package Components 585
MongoDB Reference Manual, Release 2.6.4
Use
Typically users invoke the shell with the mongo (page 580) command at the system prompt. Consider the following
examples for other scenarios.
To connect to a database on a remote host using authentication and a non-standard port, use the following form:
mongo --username <user> --password <pass> --host <host> --port 28015
Alternatively, consider the following short form:
mongo -u <user> -p <pass> --host <host> --port 28015
Replace <user>, <pass>, and <host> with the appropriate values for your situation and substitute or omit the
--port (page 631) as needed.
To execute a JavaScript le without evaluating the ~/.mongorc.js le before starting a shell session, use the
following form:
mongo --shell --norc alternate-environment.js
To execute a JavaScript le with authentication, with password prompted rather than provided on the command-line,
use the following form:
mongo script-file.js -u <user> -p
To print return a query as JSON, from the system prompt using the --eval option, use the following form:
mongo --eval 'db.collection.find().forEach(printjson)'
Use single quotes (e.g. ) to enclose the JavaScript, as well as the additional JavaScript required to generate this
output.
4.1.2 Windows Services
The mongod.exe (page 587) and mongos.exe (page 588) describe the options available for conguring MongoDB
when running as a Windows Service. The mongod.exe (page 587) and mongos.exe (page 588) binaries provide
a superset of the mongod (page 555) and mongos (page 571) options.
mongod.exe
Synopsis
mongod.exe (page 587) is the build of the MongoDB daemon (i.e. mongod (page 555)) for the Windows platform.
mongod.exe (page 587) has all of the features of mongod (page 555) on Unix-like platforms and is completely
compatible with the other builds of mongod (page 555). In addition, mongod.exe (page 587) provides several
options for interacting with the Windows platform itself.
This document only references options that are unique to mongod.exe (page 587).
All mongod (page 555) options are available. See the mongod (page 555) and the
http://docs.mongodb.org/manualreference/configuration-options documents for more
information regarding mongod.exe (page 587).
To install and use mongod.exe (page 587), read the http://docs.mongodb.org/manualtutorial/install-mongodb-on-windows
document.
586 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Options
mongod.exe
mongod.exe
command line option!install
--install
Installs mongod.exe (page 587) as a Windows Service and exits.
If needed, you can install services for multiple instances of mongod.exe (page 587). Install each service with
a unique --serviceName (page 588) and --serviceDisplayName (page 589). Use multiple instances
only when sufcient system resources exist and your system design requires it.
command line option!remove
--remove
Removes the mongod.exe (page 587) Windows Service. If mongod.exe (page 587) is running, this opera-
tion will stop and then remove the service.
--remove (page 588) requires the --serviceName (page 588) if you congured a non-default
--serviceName (page 588) during the --install (page 588) operation.
command line option!reinstall
--reinstall
Removes mongod.exe (page 587) and reinstalls mongod.exe (page 587) as a Windows Service.
command line option!serviceName name
--serviceName name
Default: MongoDB
Set the service name of mongod.exe (page 587) when running as a Windows Service. Use this name with the
net start <name> and net stop <name> operations.
You must use --serviceName (page 588) in conjunction with either the --install (page 588) or
--remove (page 588) install option.
command line option!serviceDisplayName <name>
--serviceDisplayName <name>
Default: MongoDB
Sets the name listed for MongoDB on the Services administrative application.
command line option!serviceDescription <description>
--serviceDescription <description>
Default: MongoDB Server
Sets the mongod.exe (page 587) service description.
You must use --serviceDescription (page 589) in conjunction with the --install (page 588) option.
For descriptions that contain spaces, you must enclose the description in quotes.
command line option!serviceUser <user>
--serviceUser <user>
Runs the mongod.exe (page 587) service in the context of a certain user. This user must have Log on as a
service privileges.
You must use --serviceUser (page 589) in conjunction with the --install (page 588) option.
4.1. MongoDB Package Components 587
MongoDB Reference Manual, Release 2.6.4
command line option!servicePassword <password>
--servicePassword <password>
Sets the password for <user> for mongod.exe (page 587) when running with the --serviceUser
(page 589) option.
You must use --servicePassword (page 589) in conjunction with the --install (page 588) option.
mongos.exe
Synopsis
mongos.exe (page 588) is the build of the MongoDB Shard (i.e. mongos (page 571)) for the Windows platform.
mongos.exe (page 588) has all of the features of mongos (page 571) on Unix-like platforms and is completely
compatible with the other builds of mongos (page 571). In addition, mongos.exe (page 588) provides several
options for interacting with the Windows platform itself.
This document only references options that are unique to mongos.exe (page 588).
All mongos (page 571) options are available. See the mongos (page 570) and the
http://docs.mongodb.org/manualreference/configuration-options documents for more
information regarding mongos.exe (page 588).
To install and use mongos.exe (page 588), read the http://docs.mongodb.org/manualtutorial/install-mongodb-on-windows
document.
Options
mongos.exe
mongos.exe
command line option!install
--install
Installs mongos.exe (page 588) as a Windows Service and exits.
If needed, you can install services for multiple instances of mongos.exe (page 588). Install each service with
a unique --serviceName (page 588) and --serviceDisplayName (page 589). Use multiple instances
only when sufcient system resources exist and your system design requires it.
command line option!remove
--remove
Removes the mongos.exe (page 588) Windows Service. If mongos.exe (page 588) is running, this opera-
tion will stop and then remove the service.
--remove (page 588) requires the --serviceName (page 588) if you congured a non-default
--serviceName (page 588) during the --install (page 588) operation.
command line option!reinstall
--reinstall
Removes mongos.exe (page 588) and reinstalls mongos.exe (page 588) as a Windows Service.
command line option!serviceName name
--serviceName name
Default: MongoS
588 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Set the service name of mongos.exe (page 588) when running as a Windows Service. Use this name with the
net start <name> and net stop <name> operations.
You must use --serviceName (page 588) in conjunction with either the --install (page 588) or
--remove (page 588) install option.
command line option!serviceDisplayName <name>
--serviceDisplayName <name>
Default: Mongo DB Router
Sets the name listed for MongoDB on the Services administrative application.
command line option!serviceDescription <description>
--serviceDescription <description>
Default: Mongo DB Sharding Router
Sets the mongos.exe (page 588) service description.
You must use --serviceDescription (page 589) in conjunction with the --install (page 588) option.
For descriptions that contain spaces, you must enclose the description in quotes.
command line option!serviceUser <user>
--serviceUser <user>
Runs the mongos.exe (page 588) service in the context of a certain user. This user must have Log on as a
service privileges.
You must use --serviceUser (page 589) in conjunction with the --install (page 588) option.
command line option!servicePassword <password>
--servicePassword <password>
Sets the password for <user> for mongos.exe (page 588) when running with the --serviceUser
(page 589) option.
You must use --servicePassword (page 589) in conjunction with the --install (page 588) option.
4.1.3 Binary Import and Export Tools
mongodump (page 590) provides a method for creating BSON dump les from the mongod (page 555) instances,
while mongorestore (page 597) makes it possible to restore these dumps. bsondump (page 603) converts BSON
dump les into JSON. The mongooplog (page 604) utility provides the ability to stream oplog entries outside of
normal replication.
mongodump
Synopsis
mongodump (page 590) is a utility for creating a binary export of the contents of a database. Consider using this
utility as part an effective backup strategy. Use mongodump (page 590) in conjunction with mongorestore
(page 597) to restore databases.
mongodump (page 590) can read data from either mongod (page 555) or mongos (page 571) instances, in addition
to reading directly from MongoDB data les without an active mongod (page 555).
See also:
4.1. MongoDB Package Components 589
MongoDB Reference Manual, Release 2.6.4
mongorestore (page 597), http://docs.mongodb.org/manualtutorial/backup-sharded-cluster-with-database-dumps
and http://docs.mongodb.org/manualcore/backups.
Behavior
mongodump (page 590) does not dump the content of the local database.
The data format used by mongodump (page 590) from version 2.2 or later is incompatible with earlier versions of
mongod (page 555). Do not use recent versions of mongodump (page 590) to back up older data stores.
When running mongodump (page 590) against a mongos (page 571) instance where the sharded cluster consists of
replica sets, the read preference of the operation will prefer reads from secondary members of the set.
Changed in version 2.2: When used in combination with fsync (page 328) or db.fsyncLock() (page 115),
mongod (page 555) may block some reads, including those from mongodump (page 590), when queued write oper-
ation waits behind the fsync (page 328) lock.
mongodump (page 590) overwrites output les if they exist in the backup data folder. Before running the
mongodump (page 590) command multiple times, either ensure that you no longer need the les in the output folder
(the default is the dump/ folder) or rename the folders or les.
Required Access
Backup Collections To backup all the databases in a cluster via mongodump (page 590), you should have the
backup role. The backup role provides all the needed privileges for backing up all database. The role confers no
additional access, in keeping with the policy of least privilege.
To backup a given database, you must have read access on the database. Several roles provide this access, including
the backup role.
To backup the system.profile collection in a database, you must have read access on certain system collections
in the database. Several roles provide this access, including the clusterAdmin and dbAdmin roles.
Backup Users Changed in version 2.6.
To backup users and user-dened roles for a given database, you must have access to the admin database. MongoDB
stores the user data and role denitions for all databases in the admin database.
Specically, to backup a given databases users, you must have the find action on the admin databases
admin.system.users (page 655) collection. The backup and userAdminAnyDatabase roles both provide
this privilege.
To backup the user-dened roles on a database, you must have the find action on the admin databases
admin.system.roles (page 655) collection. Both the backup and userAdminAnyDatabase roles provide
this privilege.
Options
mongodump
mongodump
command line option!help
--help
Returns information on the options and use of mongodump (page 590).
590 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongodump (page 590) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the mongodump (page 590) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the mongodump
(page 590) attempts to connect to a MongoDB instance running on the localhost on port number 27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongodump (page 590) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
4.1. MongoDB Package Components 591
MongoDB Reference Manual, Release 2.6.4
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongodump (page 590) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongodump (page 590) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
592 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongodump (page 590) to use the FIPS mode of the installed OpenSSL library. Your system must
have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentica-
tion database, the mongodump (page 590) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongodump (page 590) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
17
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
18
.
command line option!dbpath <path>
15
http://www.mongodb.com/products/mongodb-enterprise
16
http://www.mongodb.com/products/mongodb-enterprise
17
http://www.mongodb.com/products/mongodb-enterprise
18
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 593
MongoDB Reference Manual, Release 2.6.4
--dbpath <path>
Species the directory of the MongoDB data les. The --dbpath (page 600) option lets the mongodump
(page 590) attach directly to the local data les without going through a running mongod (page 555). When run
with --dbpath (page 600), the mongodump (page 590) locks access to the data les. No mongod (page 555)
can access the les while the mongodump (page 590) process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows the mongodump
(page 590) to access data from MongoDB instances that use an on-disk format where every database has a
distinct directory. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongodump (page 590) enables journaling by default on
64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species a database to backup. If you do not specify a database, mongodump (page 590) copies all databases
in this instance into the dump les.
command line option!collection <collection>, -c
--collection <collection>, -c
Species a collection to backup. If you do not specify a collection, this option copies all collections in the
specied database or instance to the dump les.
command line option!out <path>, -o
--out <path>, -o
Species the directory where mongodump (page 590) saves the output of the database dump. By default,
mongodump (page 590) saves output les in a directory named dump in the current working directory.
To send the database dump to standard output, specify - instead of a path. Write to standard output if you
want process the output before saving it, such as to use gzip to compress the dump. When writing standard
output, mongodump (page 590) does not write the metadata that writes in a <dbname>.metadata.json
le when writing to les directly.
command line option!query <json>, -q
--query <json>, -q
Provides a JSON document as a query that optionally limits the documents included in the output of
mongodump (page 590).
command line option!oplog
--oplog
Ensures that mongodump (page 590) creates a dump of the database that includes a partial oplog containing
operations from the duration of the mongodump (page 590) operation. This oplog produces an effective point-
in-time snapshot of the state of a mongod (page 555) instance. To restore to a specic point-in-time backup,
use the output created with this option in conjunction with mongorestore --oplogReplay.
Without --oplog (page 594), if there are write operations during the dump operation, the dump will not reect
a single moment in time. Changes made to the database during the update process can affect the output of the
backup.
594 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--oplog (page 594) has no effect when running mongodump (page 590) against a mongos (page 571)
instance to dump the entire contents of a sharded cluster. However, you can use --oplog (page 594) to dump
individual shards.
--oplog (page 594) only works against nodes that maintain an oplog. This includes all members of a replica
set, as well as master nodes in master/slave replication deployments.
--oplog (page 594) does not dump the oplog collection.
command line option!repair
--repair
Runs a repair option in addition to dumping the database. The repair option attempts to repair a database that
may be in an invalid state as a result of an improper shutdown or mongod (page 555) crash.
The --repair (page 595) option uses aggressive data-recovery algorithms that may produce a large amount
of duplication.
command line option!forceTableScan
--forceTableScan
Forces mongodump (page 590) to scan the data store directly: typically, mongodump (page 590) saves entries
as they appear in the index of the _id eld. If you specify a query --query (page 620), mongodump
(page 590) will use the most appropriate index to support that query.
Use --forceTableScan (page 621) to skip the index and scan the data directly. Typically there are two
cases where this behavior is preferable to the default:
1.If you have key sizes over 800 bytes that would not be present in the _id index.
2.Your database uses a custom _id eld.
When you run with --forceTableScan (page 621), mongodump (page 590) does not use $snapshot
(page 534). As a result, the dump produced by mongodump (page 590) can reect the state of the database at
many different points in time.
Important: Use --forceTableScan (page 621) with extreme caution and consideration.
command line option!dumpDbUsersAndRoles
--dumpDbUsersAndRoles
Includes user and role denitions when performing mongodump (page 590) on a specic database. This option
applies only when you specify a database in the --db (page 600) option. MongoDB always includes user and
role denitions when mongodump (page 590) applies to an entire instance and not just a specic database.
Use
See the http://docs.mongodb.org/manualtutorial/backup-with-mongodump for a larger
overview of mongodump (page 590) usage. Also see the mongorestore (page 596) document for an overview of
the mongorestore (page 597), which provides the related inverse functionality.
The following command creates a dump le that contains only the collection named collection in the database
named test. In this case the database is running on the local interface on port 27017:
mongodump --collection collection --db test
In the next example, mongodump (page 590) creates a backup of the database instance stored in the /srv/mongodb
directory on the local machine. This requires that no mongod (page 555) instance is using the /srv/mongodb
directory.
4.1. MongoDB Package Components 595
MongoDB Reference Manual, Release 2.6.4
mongodump --dbpath /srv/mongodb
In the nal example, mongodump (page 590) creates a database dump located at
http://docs.mongodb.org/manualopt/backup/mongodump-2011-10-24, from a database running
on port 37017 on the host mongodb1.example.net and authenticating using the username user and the
password pass, as follows:
mongodump --host mongodb1.example.net --port 37017 --username user --password pass --out /opt/backup/mongodump-2011-10-24
mongorestore
Synopsis
The mongorestore (page 597) program writes data from a binary database dump created by mongodump
(page 590) to a MongoDB instance. mongorestore (page 597) can create a new database or add data to an ex-
isting database.
mongorestore (page 597) can write data to either mongod or mongos (page 571) instances, in addition to writing
directly to MongoDB data les without an active mongod (page 555).
Behavior
If you restore to an existing database, mongorestore (page 597) will only insert into the existing database, and
does not perform updates of any kind. If existing documents have the same value _id eld in the target database and
collection, mongorestore (page 597) will not overwrite those documents.
Remember the following properties of mongorestore (page 597) behavior:
mongorestore (page 597) recreates indexes recorded by mongodump (page 590).
all operations are inserts, not updates.
mongorestore (page 597) does not wait for a response from a mongod (page 555) to ensure that the Mon-
goDB process has received or recorded the operation.
The mongod (page 555) will record any errors to its log that occur during a restore operation, but
mongorestore (page 597) will not receive errors.
The data format used by mongodump (page 590) from version 2.2 or later is incompatible with earlier versions of
mongod (page 555). Do not use recent versions of mongodump (page 590) to back up older data stores.
Required Access to Restore User Data
Changed in version 2.6.
To restore users and user-dened roles on a given database, you must have access to the admin database. MongoDB
stores the user data and role denitions for all databases in the admin database.
Specically, to restore users to a given database, you must have the insert action on the admin databases
admin.system.users (page 655) collection. The restore role provides this privilege.
To restore user-dened roles to a database, you must have the insert action on the admin databases
admin.system.roles (page 655) collection. The restore role provides this privilege.
596 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Options
mongorestore
mongorestore
command line option!help
--help
Returns information on the options and use of mongorestore (page 597).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongorestore (page 597) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the mongorestore (page 597) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the
mongorestore (page 597) attempts to connect to a MongoDB instance running on the localhost on port
number 27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongorestore (page 597) to connect to the MongoDB instance using
an IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
4.1. MongoDB Package Components 597
MongoDB Reference Manual, Release 2.6.4
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongorestore (page 597) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongorestore (page 597) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
598 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongorestore (page 597) to use the FIPS mode of the installed OpenSSL library. Your system
must have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentication
database, the mongorestore (page 597) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongorestore (page 597) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
4.1. MongoDB Package Components 599
MongoDB Reference Manual, Release 2.6.4
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
21
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
22
.
command line option!dbpath <path>
--dbpath <path>
Species the directory of the MongoDB data les. The --dbpath (page 600) option lets the mongorestore
(page 597) attach directly to the local data les without going through a running mongod (page 555). When
run with --dbpath (page 600), the mongorestore (page 597) locks access to the data les. No mongod
(page 555) can access the les while the mongorestore (page 597) process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows the mongorestore
(page 597) to access data from MongoDB instances that use an on-disk format where every database has a
distinct directory. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongorestore (page 597) enables journaling by default
on 64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species a database for mongorestore (page 597) to restore data into. If the database does not exist,
mongorestore (page 597) creates the database. If you do not specify a <db>, mongorestore (page 597)
creates new databases that correspond to the databases where data originated and data may be overwritten. Use
this option to restore data into a MongoDB instance that already has data.
--db (page 600) does not control which BSON les mongorestore (page 597) restores. You must use the
mongorestore (page 597) path option (page 602) to limit that restored data.
command line option!collection <collection>, -c
--collection <collection>, -c
Species a single collection for mongorestore (page 597) to restore. If you do not specify --collection
(page 600), mongorestore (page 597) takes the collection name from the input lename. If the input le has
an extension, MongoDB omits the extension of the le from the collection name.
command line option!objcheck
--objcheck
Forces mongorestore (page 597) to validate all requests from clients upon receipt to ensure that clients
never insert invalid documents into the database. For objects with a high degree of sub-document nesting,
19
http://www.mongodb.com/products/mongodb-enterprise
20
http://www.mongodb.com/products/mongodb-enterprise
21
http://www.mongodb.com/products/mongodb-enterprise
22
http://www.mongodb.com/products/mongodb-enterprise
600 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--objcheck (page 636) can have a small impact on performance. You can set --noobjcheck (page 601)
to disable object checking at run-time.
Changed in version 2.4: MongoDB enables --objcheck (page 636) by default, to prevent any client from
inserting malformed or invalid BSON into a MongoDB database.
command line option!noobjcheck
--noobjcheck
New in version 2.4.
Disables the default document validation that MongoDB performs on all incoming BSON documents.
command line option!lter <JSON>
--filter <JSON>
Limits the documents that mongorestore (page 597) imports to only those documents that match the JSON
document specied as <JSON>. Be sure to include the document in single quotes to avoid interaction with
your systems shell environment. For an example of --filter (page 601), see backup-restore-lter.
command line option!drop
--drop
Modies the restoration procedure to drop every collection from the target database before restoring the collec-
tion from the dumped backup.
command line option!oplogReplay
--oplogReplay
Replays the oplog after restoring the dump to ensure that the current state of the database reects the point-in-
time backup captured with the mongodump --oplog command. For an example of --oplogReplay
(page 601), see backup-restore-oplogreplay.
command line option!oplogLimit <timestamp>
--oplogLimit <timestamp>
New in version 2.2.
Prevents mongorestore (page 597) from applying oplog entries with timestamp newer than or equal to
<timestamp>. Specify <timestamp> values in the form of <time_t>:<ordinal>, where <time_t>
is the seconds since the UNIX epoch, and <ordinal> represents a counter of operations in the oplog that
occurred in the specied second.
You must use --oplogLimit (page 601) in conjunction with the --oplogReplay (page 601) option.
command line option!keepIndexVersion
--keepIndexVersion
Prevents mongorestore (page 597) from upgrading the index to the latest version during the restoration
process.
command line option!noIndexRestore
--noIndexRestore
New in version 2.2.
Prevents mongorestore (page 597) from restoring and building indexes as specied in the corresponding
mongodump (page 590) output.
command line option!noOptionsRestore
--noOptionsRestore
New in version 2.2.
4.1. MongoDB Package Components 601
MongoDB Reference Manual, Release 2.6.4
Prevents mongorestore (page 597) from setting the collection options, such as those specied by the
collMod (page 314) database command, on restored collections.
command line option!restoreDbUsersAndRoles
--restoreDbUsersAndRoles
Restore user and role denitions for the given database. See http://docs.mongodb.org/manualreference/system-roles-collection
and http://docs.mongodb.org/manualreference/system-users-collection for more
information.
command line option!w <number of replicas per write>
--w <number of replicas per write>
New in version 2.2.
Species the write concern for each write operation that mongorestore (page 597) writes to the target
database. By default, mongorestore (page 597) does not wait for a response for write acknowledgment.
<path>
The nal argument of the mongorestore (page 597) command is a directory path. This argument species
the location of the database dump from which to restore.
Use
See http://docs.mongodb.org/manualtutorial/backup-with-mongodump for a larger overview
of mongorestore (page 597) usage. Also see the mongodump (page 589) document for an overview of the
mongodump (page 590), which provides the related inverse functionality.
Consider the following example:
mongorestore --collection people --db accounts dump/accounts/people.bson
Here, mongorestore (page 597) reads the database dump in the dump/ sub-directory of the current directory, and
restores only the documents in the collection named people fromthe database named accounts. mongorestore
(page 597) restores data to the instance running on the localhost interface on port 27017.
In the next example, mongorestore (page 597) restores a backup of the database instance located in dump to a
database instance stored in the /srv/mongodb on the local machine. This requires that there are no active mongod
(page 555) instances attached to /srv/mongodb data directory.
mongorestore --dbpath /srv/mongodb
In the nal example, mongorestore (page 597) restores a database dump located at
http://docs.mongodb.org/manualopt/backup/mongodump-2011-10-24, to a database run-
ning on port 37017 on the host mongodb1.example.net. The mongorestore (page 597) command
authenticates to the MongoDB instance using the username user and the password pass, as follows:
mongorestore --host mongodb1.example.net --port 37017 --username user --password pass /opt/backup/mongodump-2011-10-24
bsondump
Synopsis
The bsondump (page 603) converts BSON les into human-readable formats, including JSON. For example,
bsondump (page 603) is useful for reading the output les generated by mongodump (page 590).
Important: bsondump (page 603) is a diagnostic tool for inspecting BSON les, not a tool for data ingestion or
602 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
other application use.
Options
bsondump
bsondump
command line option!help
--help
Returns information on the options and use of bsondump (page 603).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the bsondump (page 603) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the bsondump (page 603) release number.
command line option!objcheck
--objcheck
Validates each BSON object before outputting it in JSON format. By default, bsondump (page 603) enables
--objcheck (page 636). For objects with a high degree of sub-document nesting, --objcheck (page 636)
can have a small impact on performance. You can set --noobjcheck (page 601) to disable object checking.
Changed in version 2.4: MongoDB enables --objcheck (page 636) by default, to prevent any client from
inserting malformed or invalid BSON into a MongoDB database.
command line option!noobjcheck
--noobjcheck
New in version 2.4.
Disables the default document validation that MongoDB performs on all incoming BSON documents.
command line option!lter <JSON>
--filter <JSON>
Limits the documents that bsondump (page 603) exports to only those documents that match the JSON docu-
ment specied as <JSON>. Be sure to include the document in single quotes to avoid interaction with your
systems shell environment.
command line option!type <=json|=debug>
4.1. MongoDB Package Components 603
MongoDB Reference Manual, Release 2.6.4
--type <=json|=debug>
Changes the operation of bsondump (page 603) from outputting JSON (the default) to a debugging format.
<bsonFilename>
The nal argument to bsondump (page 603) is a document containing BSON. This data is typically generated
by bsondump (page 603) or by MongoDB in a rollback operation.
Use
By default, bsondump (page 603) outputs data to standard output. To create corresponding JSON les, you will need
to use the shell redirect. See the following command:
bsondump collection.bson > collection.json
Use the following command (at the system shell) to produce debugging output for a BSON le:
bsondump --type=debug collection.bson
mongooplog
New in version 2.2.
Synopsis
mongooplog (page 604) is a simple tool that polls operations from the replication oplog of a remote server, and
applies them to the local server. This capability supports certain classes of real-time migrations that require that the
source server remain online and in operation throughout the migration process.
Typically this command will take the following form:
mongooplog --from mongodb0.example.net --host mongodb1.example.net
This command copies oplog entries from the mongod (page 555) instance running on the host
mongodb0.example.net and duplicates operations to the host mongodb1.example.net. If you do
not need to keep the --from host running during the migration, consider using mongodump (page 590) and
mongorestore (page 597) or another backup operation, which may be better suited to your operation.
Note: If the mongod (page 555) instance specied by the --from argument is running with authentication,
then mongooplog (page 604) will not be able to copy oplog entries.
See also:
mongodump (page 590), mongorestore (page 597), http://docs.mongodb.org/manualcore/backups,
http://docs.mongodb.org/manualcore/replica-set-oplog.
Options
mongooplog
mongooplog
command line option!help
--help
Returns information on the options and use of mongooplog (page 604).
604 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongooplog (page 604) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
connection accepted events
connection closed events
command line option!version
--version
Returns the mongooplog (page 604) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Species a resolvable hostname for the mongod (page 555) instance to which mongooplog (page 604) will
apply oplog operations retrieved from the server specied by the --from option.
By default mongooplog (page 604) attempts to connect to a MongoDB instance running on the localhost on
port number 27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port
--port
Species the port number of the mongod (page 555) instance where mongooplog (page 604) will apply oplog
entries. Specify this option only if the MongoDB instance to connect to is not running on the standard port of
27017. You may also specify a port number using the --host command.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongooplog (page 604) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
4.1. MongoDB Package Components 605
MongoDB Reference Manual, Release 2.6.4
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongooplog (page 604) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongooplog (page 604) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
606 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongooplog (page 604) to use the FIPS mode of the installed OpenSSL library. Your system must
have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentica-
tion database, the mongooplog (page 604) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongooplog (page 604) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
25
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
26
.
command line option!dbpath <path>
23
http://www.mongodb.com/products/mongodb-enterprise
24
http://www.mongodb.com/products/mongodb-enterprise
25
http://www.mongodb.com/products/mongodb-enterprise
26
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 607
MongoDB Reference Manual, Release 2.6.4
--dbpath <path>
Species a directory, containing MongoDB data les, to which mongooplog (page 604) will apply operations
from the oplog of the database specied with the --from option.
When used, the --dbpath (page 600) option enables mongo (page 580) to attach directly to local data les
and write data without a running mongod (page 555) instance.
To run with --dbpath (page 600), mongooplog (page 604) needs to restrict access to the data directory: as
a result, no mongod (page 555) can be access the same path while the process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows the mongooplog
(page 604) to access data from MongoDB instances that use an on-disk format where every database has a
distinct directory. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongooplog (page 604) enables journaling by default on
64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species the name of the database on which to run the mongooplog (page 604).
command line option!collection <collection>, -c
--collection <collection>, -c
Species the collection to export.
command line option!seconds <number>, -s
--seconds <number>, -s
Specify a number of seconds of operations for mongooplog (page 604) to pull from the remote host.
Unless specied the default value is 86400 seconds, or 24 hours.
command line option!from <host[:port]>
--from <host[:port]>
Specify the host for mongooplog (page 604) to retrieve oplog operations from. mongooplog (page 604)
requires this option.
Unless you specify the --host option, mongooplog (page 604) will apply the operations collected with this
option to the oplog of the mongod (page 555) instance running on the localhost interface connected to port
27017.
command line option!oplogns <namespace>
--oplogns <namespace>
Specify a namespace in the --from host where the oplog resides. The default value is local.oplog.rs,
which is the where replica set members store their operation log. However, if youve copied oplog entries
into another database or collection or are pulling oplog entries from a master-slave deployment, use
--oplogns (page 608) to apply oplog entries stored in another location. Namespaces take the form of
[database].[collection].
Use
Consider the following prototype mongooplog (page 604) command:
608 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
mongooplog --from mongodb0.example.net --host mongodb1.example.net
Here, entries from the oplog of the mongod (page 555) running on port 27017. This only pull entries from the last
24 hours.
Use the --seconds argument to capture a greater or smaller amount of time. Consider the following example:
mongooplog --from mongodb0.example.net --seconds 172800
In this operation, mongooplog (page 604) captures 2 full days of operations. To migrate 12 hours of oplog entries,
use the following form:
mongooplog --from mongodb0.example.net --seconds 43200
For the previous two examples, mongooplog (page 604) migrates entries to the mongod (page 555) process running
on the localhost interface connected to the 27017 port. mongooplog (page 604) can also operate directly on
MongoDBs data les if no mongod (page 555) is running on the target host. Consider the following example:
mongooplog --from mongodb0.example.net --dbpath /srv/mongodb --journal
Here, mongooplog (page 604) imports oplog operations from the mongod (page 555) host connected to port
27017. This migrates operations to the MongoDB data les stored in the /srv/mongodb directory. Addition-
ally mongooplog (page 604) will use the durability journal to ensure that the data les remain valid.
4.1.4 Data Import and Export Tools
mongoimport (page 610) provides a method for taking data in JSON, CSV, or TSV and importing it into a mongod
(page 555) instance. mongoexport (page 616) provides a method to export data from a mongod (page 555) instance
into JSON, CSV, or TSV.
Note: The conversion between BSON and other formats lacks full type delity. Therefore you cannot use
mongoimport (page 610) and mongoexport (page 616) for round-trip import and export operations.
mongoimport
Synopsis
The mongoimport (page 610) tool provides a route to import content from a JSON, CSV, or TSV
export created by mongoexport (page 616), or potentially, another third-party export tool. See the
http://docs.mongodb.org/manualcore/import-export document for a more in depth usage
overview, and the mongoexport (page 616) document for more information regarding mongoexport (page 616),
which provides the inverse exporting capability.
Considerations
Do not use mongoimport (page 610) and mongoexport (page 616) for full instance, production backups because
they will not reliably capture data type information. Use mongodump (page 590) and mongorestore (page 597)
as described in http://docs.mongodb.org/manualcore/backups for this kind of functionality.
mongoimport (page 610) is single-threaded and inserts one document at a time into MongoDB. Custom import
tools for data ingestion may have better performance for specic workloads.
4.1. MongoDB Package Components 609
MongoDB Reference Manual, Release 2.6.4
Options
mongoimport
mongoimport
command line option!help
--help
Returns information on the options and use of mongoimport (page 610).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongoimport (page 610) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the mongoimport (page 610) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the
mongoimport (page 610) attempts to connect to a MongoDBinstance running on the localhost on port number
27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongoimport (page 610) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
610 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongoimport (page 610) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongoimport (page 610) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
4.1. MongoDB Package Components 611
MongoDB Reference Manual, Release 2.6.4
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongoimport (page 610) to use the FIPS mode of the installed OpenSSL library. Your system
must have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentication
database, the mongoimport (page 610) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongoimport (page 610) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
612 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
29
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
30
.
command line option!dbpath <path>
--dbpath <path>
Species the directory of the MongoDB data les. The --dbpath (page 600) option lets the mongoimport
(page 610) attach directly to the local data les without going through a running mongod (page 555). When
run with --dbpath (page 600), the mongoimport (page 610) locks access to the data les. No mongod
(page 555) can access the les while the mongoimport (page 610) process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows the mongoimport
(page 610) to access data from MongoDB instances that use an on-disk format where every database has a
distinct directory. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongoimport (page 610) enables journaling by default
on 64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species the name of the database on which to run the mongoimport (page 610).
command line option!collection <collection>, -c
--collection <collection>, -c
Species the collection to import.
New in version 2.6: If you do not specify --collection (page 600), mongoimport (page 610) takes the
collection name from the input lename. MongoDB omits the extension of the le from the collection name, if
the input le has an extension.
command line option!elds <eld1[,eld2]>, -f
--fields <field1[,field2]>, -f
Specify a comma separated list of eld names when importing csv or tsv les that do not have eld names in the
rst (i.e. header) line of the le.
command line option!eldFile <lename>
--fieldFile <filename>
As an alternative to --fields (page 613), the --fieldFile (page 613) option allows you to specify a le
27
http://www.mongodb.com/products/mongodb-enterprise
28
http://www.mongodb.com/products/mongodb-enterprise
29
http://www.mongodb.com/products/mongodb-enterprise
30
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 613
MongoDB Reference Manual, Release 2.6.4
that holds a list of eld names if your csv or tsv le does not include eld names in the rst line of the le (i.e.
header). Place one eld per line.
command line option!ignoreBlanks
--ignoreBlanks
Ignores empty elds in csv and tsv exports. If not specied, mongoimport (page 610) creates elds without
values in imported documents.
command line option!type <json|csv|tsv>
--type <json|csv|tsv>
Species the le type to import. The default format is JSON, but its possible to import csv and tsv les.
The csv parser accepts that data that complies with RFC RFC 4180
31
. As a result, backslashes are not a
valid escape character. If you use double-quotes to enclose elds in the CSV data, you must escape internal
double-quote marks by prepending another double-quote.
command line option!le <lename>
--file <filename>
Species the location and name of a le containing the data to import. If you do not specify a le,
mongoimport (page 610) reads data from standard input (e.g. stdin).
command line option!drop
--drop
Modies the import process so that the target instance drops every collection before importing the collection
from the input.
command line option!headerline
--headerline
If using --type csv or --type tsv, uses the rst line as eld names. Otherwise, mongoimport
(page 610) will import the rst line as a distinct document.
command line option!upsert
--upsert
Modies the import process to update existing objects in the database if they match an imported object, while
inserting all other objects.
If you do not specify a eld or elds using the --upsertFields (page 614) mongoimport (page 610) will
upsert on the basis of the _id eld.
command line option!upsertFields <eld1[,eld2]>
--upsertFields <field1[,field2]>
Species a list of elds for the query portion of the upsert. Use this option if the _id elds in the existing
documents dont match the eld in the document, but another eld or eld combination can uniquely identify
documents as a basis for performing upsert operations.
To ensure adequate performance, indexes should exist for this eld or elds.
command line option!stopOnError
--stopOnError
New in version 2.2.
Forces mongoimport (page 610) to halt the import operation at the rst error rather than continuing the
operation despite errors.
command line option!jsonArray
31
http://tools.ietf.org/html/rfc4180.html
614 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--jsonArray
Accepts the import of data expressed with multiple MongoDB documents within a single JSON array.
Used in conjunction with mongoexport --jsonArray to import data written as a single JSON array.
Limited to imports of 16 MB or smaller.
Use
In this example, mongoimport (page 610) imports the csv formatted data in the
http://docs.mongodb.org/manualopt/backups/contacts.csv into the collection contacts
in the users database on the MongoDB instance running on the localhost port numbered 27017. mongoimport
(page 610) determines the name of les using the rst line in the CSV le, because of the --headerline:
mongoimport --db users --collection contacts --type csv --headerline --file /opt/backups/contacts.csv
Since mongoimport (page 610) uses the input le name, without the extension, as the collection name if -c or
--collection is unspecied. The following following example is equivalent:
mongoimport --db users --type csv --headerline --file /opt/backups/contacts.csv
In the following example, mongoimport (page 610) imports the data in the JSON formatted le contacts.json
into the collection contacts on the MongoDB instance running on the localhost port number 27017.
mongoimport --collection contacts --file contacts.json
In the next example, mongoimport (page 610) takes data passed to it on standard input (i.e. with a | pipe.) and
imports it into the MongoDB datales located at /srv/mongodb/. if the import process encounters an error, the
mongoimport (page 610) will halt because of the --stopOnError option.
mongoimport --db sales --collection contacts --stopOnError --dbpath /srv/mongodb/
In the nal example, mongoimport (page 610) imports data from the le
http://docs.mongodb.org/manualopt/backups/mdb1-examplenet.json into the collection
contacts within the database marketing on a remote MongoDB database. This mongoimport (page 610)
accesses the mongod (page 555) instance running on the host mongodb1.example.net over port 37017, which
requires the username user and the password pass.
mongoimport --host mongodb1.example.net --port 37017 --username user --password pass --collection contacts --db marketing --file /opt/backups/mdb1-examplenet.json
Type Fidelity
Warning: mongoimport (page 610) and mongoexport (page 616) do not reliably preserve all
rich BSON data types because JSON can only represent a subset of the types supported by BSON.
As a result, data exported or imported with these tools may lose some measure of delity. See
http://docs.mongodb.org/manualreference/mongodb-extended-json for more informa-
tion.
JSON can only represent a subset of the types supported by BSON. To preserve type information, mongoimport
(page 610) accepts strict mode representation for certain types.
For example, to preserve type information for BSON types data_date and data_numberlong during
mongoimport (page 610), the data should be in strict mode representation, as in the following:
{ "_id" : 1, "volume" : { "$numberLong" : "2980000" }, "date" : { "$date" : "2014-03-13T13:47:42.483-0400" } }
4.1. MongoDB Package Components 615
MongoDB Reference Manual, Release 2.6.4
For the data_numberlong type, mongoimport (page 610) converts into a oat during the import.
See http://docs.mongodb.org/manualreference/mongodb-extended-json for a complete list of
these types and the representations used.
mongoexport
Synopsis
mongoexport (page 616) is a utility that produces a JSON or CSV export of data stored in a MongoDB instance.
See the http://docs.mongodb.org/manualcore/import-export document for a more in depth usage
overview, and the mongoimport (page 609) document for more information regarding the mongoimport (page 610)
utility, which provides the inverse importing capability.
Considerations
Do not use mongoimport (page 610) and mongoexport (page 616) for full-scale production backups because
they may not reliably capture data type information. Use mongodump (page 590) and mongorestore (page 597)
as described in http://docs.mongodb.org/manualcore/backups for this kind of functionality.
Options
mongoexport
mongoexport
command line option!help
--help
Returns information on the options and use of mongoexport (page 616).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongoexport (page 616) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the mongoexport (page 616) release number.
command line option!host <hostname><:port>, -h
616 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the
mongoexport (page 616) attempts to connect to a MongoDBinstance running on the localhost on port number
27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongoexport (page 616) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
4.1. MongoDB Package Components 617
MongoDB Reference Manual, Release 2.6.4
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongoexport (page 616) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongoexport (page 616) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongoexport (page 616) to use the FIPS mode of the installed OpenSSL library. Your system
must have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
618 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentication
database, the mongoexport (page 616) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongoexport (page 616) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
34
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
35
.
command line option!dbpath <path>
--dbpath <path>
Species the directory of the MongoDB data les. The --dbpath (page 600) option lets the mongoexport
(page 616) attach directly to the local data les without going through a running mongod (page 555). When
run with --dbpath (page 600), the mongoexport (page 616) locks access to the data les. No mongod
(page 555) can access the les while the mongoexport (page 616) process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows mongoexport
(page 616) to export data from MongoDB instances that have every databases les saved in discrete direc-
tories on the disk. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongoexport (page 616) enables journaling by default
on 64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species the name of the database on which to run the mongoexport (page 616).
32
http://www.mongodb.com/products/mongodb-enterprise
33
http://www.mongodb.com/products/mongodb-enterprise
34
http://www.mongodb.com/products/mongodb-enterprise
35
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 619
MongoDB Reference Manual, Release 2.6.4
command line option!collection <collection>, -c
--collection <collection>, -c
Species the collection to export.
command line option!elds <eld1[,eld2]>, -f
--fields <field1[,field2]>, -f
Species a eld or elds to include in the export. Use a comma separated list of elds to specify multiple elds.
For --csv output formats, mongoexport (page 616) includes only the specied eld(s), and the specied
eld(s) can be a eld within a sub-document.
For JSON output formats, mongoexport (page 616) includes only the specied eld(s) and the _id eld,
and if the specied eld(s) is a eld within a sub-document, the mongoexport (page 616) includes the sub-
document with all its elds, not just the specied eld within the document.
command line option!eldFile <lename>
--fieldFile <filename>
An alternative to --fields. The --fieldFile (page 613) option allows you to specify in a le the eld or
elds to include in the export and is only valid with the --csv option. The le must have only one eld per
line, and the line(s) must end with the LF character (0x0A).
mongoexport (page 616) includes only the specied eld(s). The specied eld(s) can be a eld within a
sub-document.
command line option!query <JSON>, -q
--query <JSON>, -q
Provides a JSON document as a query that optionally limits the documents returned in the export. Specify JSON
in strict format.
For example, given a collection named records in the database test with the following documents:
{ "_id" : ObjectId("51f0188846a64a1ed98fde7c"), "a" : 1 }
{ "_id" : ObjectId("520e61b0c6646578e3661b59"), "a" : 1, "b" : 2 }
{ "_id" : ObjectId("520e642bb7fa4ea22d6b1871"), "a" : 2, "b" : 3, "c" : 5 }
{ "_id" : ObjectId("520e6431b7fa4ea22d6b1872"), "a" : 3, "b" : 3, "c" : 6 }
{ "_id" : ObjectId("520e6445b7fa4ea22d6b1873"), "a" : 5, "b" : 6, "c" : 8 }
The following mongoexport (page 616) uses the -q (page ??) option to export only the documents with the
eld a greater than or equal to ($gte (page 387)) to 3:
mongoexport -d test -c records -q "{ a: { \$gte: 3 } }" --out exportdir/myRecords.json
The resulting le contains the following documents:
{ "_id" : { "$oid" : "520e6431b7fa4ea22d6b1872" }, "a" : 3, "b" : 3, "c" : 6 }
{ "_id" : { "$oid" : "520e6445b7fa4ea22d6b1873" }, "a" : 5, "b" : 6, "c" : 8 }
You can sort the results with the --sort (page 621) option to mongoexport (page 616).
command line option!csv
--csv
Changes the export format to a comma-separated-values (CSV) format. By default mongoexport (page 616)
writes data using one JSON document for every MongoDB document.
If you specify --csv (page 620), then you must also use either the --fields (page 613) or the
--fieldFile (page 613) option to declare the elds to export from the collection.
command line option!out <le>, -o
620 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--out <file>, -o
Species a le to write the export to. If you do not specify a le name, the mongoexport (page 616) writes
data to standard output (e.g. stdout).
command line option!jsonArray
--jsonArray
Modies the output of mongoexport (page 616) to write the entire contents of the export as a single JSON
array. By default mongoexport (page 616) writes data using one JSON document for every MongoDB docu-
ment.
command line option!slaveOk, -k
--slaveOk, -k
Allows mongoexport (page 616) to read data from secondary or slave nodes when using mongoexport
(page 616) with a replica set. This option is only available if connected to a mongod (page 555) or mongos
(page 571) and is not available when used with the mongoexport --dbpath option.
This is the default behavior.
command line option!forceTableScan
--forceTableScan
New in version 2.2.
Forces mongoexport (page 616) to scan the data store directly: typically, mongoexport (page 616) saves
entries as they appear in the index of the _id eld. Use --forceTableScan (page 621) to skip the index
and scan the data directly. Typically there are two cases where this behavior is preferable to the default:
1.If you have key sizes over 800 bytes that would not be present in the _id index.
2.Your database uses a custom _id eld.
When you run with --forceTableScan (page 621), mongoexport (page 616) does not use $snapshot
(page 534). As a result, the export produced by mongoexport (page 616) can reect the state of the database
at many different points in time.
Warning: Use --forceTableScan (page 621) with extreme caution and consideration.
command line option!skip <number>
--skip <number>
Use --skip (page 621) to control where mongoexport (page 616) begins exporting documents. See
skip() (page 95) for information about the underlying operation.
command line option!limit <number>
--limit <number>
Species a maximum number of documents to include in the export. See limit() (page 89) for information
about the underlying operation.
command line option!sort <JSON>
--sort <JSON>
Species an ordering for exported results. If an index does not exist that can support the sort operation, the
results must be less than 32 megabytes.
Use --sort (page 621) conjunction with --skip (page 621) and --limit (page 621) to limit number of
exported documents.
4.1. MongoDB Package Components 621
MongoDB Reference Manual, Release 2.6.4
mongoexport -d test -c records --sort '{a: 1}' --limit 100 --out export.0.json
mongoexport -d test -c records --sort '{a: 1}' --limit 100 --skip 100 --out export.1.json
mongoexport -d test -c records --sort '{a: 1}' --limit 100 --skip 200 --out export.2.json
See sort() (page 96) for information about the underlying operation.
Use
Export in CSV Format In the following example, mongoexport (page 616) exports the collection
contacts from the users database from the mongod (page 555) instance running on the local-
host port number 27017. This command writes the export data in CSV format into a le located at
http://docs.mongodb.org/manualopt/backups/contacts.csv. The fields.txt le contains a
line-separated list of elds to export.
mongoexport --db users --collection contacts --csv --fieldFile fields.txt --out /opt/backups/contacts.csv
Export in JSON Format The next example creates an export of the collection contacts from the MongoDB
instance running on the localhost port number 27017, with journaling explicitly enabled. This writes the export to
the contacts.json le in JSON format.
mongoexport --db sales --collection contacts --out contacts.json --journal
Export Collection Directly From Data Files The following example exports the collection contacts from the
sales database located in the MongoDB data les located at /srv/mongodb/. This operation writes the export to
standard output in JSON format.
mongoexport --db sales --collection contacts --dbpath /srv/mongodb/
Warning: The above example will only succeed if there is no mongod (page 555) connected to the data les
located in the /srv/mongodb/ directory.
Export from Remote Host Running with Authentication The following example exports the collection
contacts from the database marketing . This data resides on the MongoDB instance located on the host
mongodb1.example.net running on port 37017, which requires the username user and the password pass.
mongoexport --host mongodb1.example.net --port 37017 --username user --password pass --collection contacts --db marketing --out mdb1-examplenet.json
Type Fidelity
Warning: mongoimport (page 610) and mongoexport (page 616) do not reliably preserve all
rich BSON data types because JSON can only represent a subset of the types supported by BSON.
As a result, data exported or imported with these tools may lose some measure of delity. See
http://docs.mongodb.org/manualreference/mongodb-extended-json for more informa-
tion.
JSON can only represent a subset of the types supported by BSON. To preserve type information, mongoexport
(page 616) uses the strict mode representation for certain types.
For example, the following insert operation in the mongo (page 580) shell uses the mongoShell mode
representation for the BSON types data_date and data_numberlong:
622 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
use test
db.traffic.insert( { _id: 1, volume: NumberLong(2980000), date: new Date() } )
Use mongoexport (page 616) to export the data:
mongoexport --db test --collection traffic --out traffic.json
The exported data is in strict mode representation to preserve type information:
{ "_id" : 1, "volume" : { "$numberLong" : "2980000" }, "date" : { "$date" : "2014-03-13T13:47:42.483-0400" } }
See http://docs.mongodb.org/manualreference/mongodb-extended-json for a complete list of
these types and the representations used.
4.1.5 Diagnostic Tools
mongostat (page 624), mongotop (page 630), and mongosniff (page 635) provide diagnostic information
related to the current operation of a mongod (page 555) instance.
Note: Because mongosniff (page 635) depends on libpcap, most distributions of MongoDB do not include
mongosniff (page 635).
mongostat
Synopsis
The mongostat (page 624) utility provides a quick overview of the status of a currently running mongod (page 555)
or mongos (page 571) instance. mongostat (page 624) is functionally similar to the UNIX/Linux le system utility
vmstat, but provides data regarding mongod (page 555) and mongos (page 571) instances.
See also:
For more information about monitoring MongoDB, see http://docs.mongodb.org/manualadministration/monitoring.
For more background on various other MongoDB status outputs see:
serverStatus (page 354)
replSetGetStatus (page 289)
dbStats (page 342)
collStats (page 338)
For an additional utility that provides MongoDB metrics see mongotop (page 630).
Access Control Requirements
In order to connect to a mongod (page 555) that enforces authorization with the --auth option, specify the
--username and --password options, and the user specied must have the serverStatus privilege.
The most appropriate built-in role that has this privilege is clusterMonitor.
4.1. MongoDB Package Components 623
MongoDB Reference Manual, Release 2.6.4
Options
mongostat
mongostat
command line option!help
--help
Returns information on the options and use of mongostat (page 624).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!version
--version
Returns the mongostat (page 624) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the mongostat
(page 624) attempts to connect to a MongoDB instance running on the localhost on port number 27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongostat (page 624) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
624 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongostat (page 624) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongostat (page 624) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
4.1. MongoDB Package Components 625
MongoDB Reference Manual, Release 2.6.4
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongostat (page 624) to use the FIPS mode of the installed OpenSSL library. Your system must
have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentica-
tion database, the mongostat (page 624) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongostat (page 624) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
38
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
39
.
command line option!noheaders
--noheaders
Disables the output of column or eld names.
36
http://www.mongodb.com/products/mongodb-enterprise
37
http://www.mongodb.com/products/mongodb-enterprise
38
http://www.mongodb.com/products/mongodb-enterprise
39
http://www.mongodb.com/products/mongodb-enterprise
626 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
command line option!rowcount <number>, -n
--rowcount <number>, -n
Controls the number of rows to output. Use in conjunction with the sleeptime argument to control the
duration of a mongostat (page 624) operation.
Unless --rowcount (page 627) is specied, mongostat (page 624) will return an innite number of rows
(e.g. value of 0.)
command line option!http
--http
Congures mongostat (page 624) to collect data using the HTTP interface rather than a raw database con-
nection.
command line option!discover
--discover
Discovers and reports on statistics from all members of a replica set or sharded cluster. When connected to any
member of a replica set, --discover (page 627) all non-hidden members of the replica set. When connected
to a mongos (page 571), mongostat (page 624) will return data from all shards in the cluster. If a replica
set provides a shard in the sharded cluster, mongostat (page 624) will report on non-hidden members of that
replica set.
The mongostat --host option is not required but potentially useful in this case.
Changed in version 2.6: When running with --discover (page 627), mongostat (page 624) now respects
:option:rowcount.
command line option!all
--all
Congures mongostat (page 624) to return all optional elds (page 627).
<sleeptime>
The nal argument is the length of time, in seconds, that mongostat (page 624) waits in between calls. By
default mongostat (page 624) returns one call every second.
mongostat (page 624) returns values that reect the operations over a 1 second period. For values of
<sleeptime> greater than 1, mongostat (page 624) averages data to reect average operations per sec-
ond.
Fields
mongostat (page 624) returns values that reect the operations over a 1 second period. When mongostat <sleep-
time> has a value greater than 1, mongostat (page 624) averages the statistics to reect average operations per
second.
mongostat (page 624) outputs the following elds:
inserts
The number of objects inserted into the database per second. If followed by an asterisk (e.g.
*
), the datum refers
to a replicated operation.
query
The number of query operations per second.
update
The number of update operations per second.
delete
The number of delete operations per second.
4.1. MongoDB Package Components 627
MongoDB Reference Manual, Release 2.6.4
getmore
The number of get more (i.e. cursor batch) operations per second.
command
The number of commands per second. On slave and secondary systems, mongostat (page 624) presents two
values separated by a pipe character (e.g. |), in the form of local|replicated commands.
flushes
The number of fsync operations per second.
mapped
The total amount of data mapped in megabytes. This is the total data size at the time of the last mongostat
(page 624) call.
size
The amount of virtual memory in megabytes used by the process at the time of the last mongostat (page 624)
call.
non-mapped
The total amount of virtual memory excluding all mapped memory at the time of the last mongostat
(page 624) call.
res
The amount of resident memory in megabytes used by the process at the time of the last mongostat (page 624)
call.
faults
Changed in version 2.1.
The number of page faults per second.
Before version 2.1 this value was only provided for MongoDB instances running on Linux hosts.
locked
The percent of time in a global write lock.
Changed in version 2.2: The locked db eld replaces the locked % eld to more appropriate data regarding
the database specic locks in version 2.2.
locked db
New in version 2.2.
The percent of time in the per-database context-specic lock. mongostat (page 624) will report the database
that has spent the most time since the last mongostat (page 624) call with a write lock.
This value represents the amount of time that the listed database spent in a locked state combined with the time
that the mongod (page 555) spent in the global lock. Because of this, and the sampling method, you may see
some values greater than 100%.
idx miss
The percent of index access attempts that required a page fault to load a btree node. This is a sampled value.
qr
The length of the queue of clients waiting to read data from the MongoDB instance.
qw
The length of the queue of clients waiting to write data from the MongoDB instance.
ar
The number of active clients performing read operations.
aw
The number of active clients performing write operations.
628 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
netIn
The amount of network trafc, in bytes, received by the MongoDB instance.
This includes trafc from mongostat (page 624) itself.
netOut
The amount of network trafc, in bytes, sent by the MongoDB instance.
This includes trafc from mongostat (page 624) itself.
conn
The total number of open connections.
set
The name, if applicable, of the replica set.
repl
The replication status of the member.
Value Replication Type
M master
SEC secondary
REC recovering
UNK unknown
SLV slave
RTR mongos process (router)
Usage
In the rst example, mongostat (page 624) will return data every second for 20 seconds. mongostat (page 624)
collects data from the mongod (page 555) instance running on the localhost interface on port 27017. All of the
following invocations produce identical behavior:
mongostat --rowcount 20 1
mongostat --rowcount 20
mongostat -n 20 1
mongostat -n 20
In the next example, mongostat (page 624) returns data every 5 minutes (or 300 seconds) for as long as the program
runs. mongostat (page 624) collects data from the mongod (page 555) instance running on the localhost interface
on port 27017. Both of the following invocations produce identical behavior.
mongostat --rowcount 0 300
mongostat -n 0 300
mongostat 300
In the following example, mongostat (page 624) returns data every 5 minutes for an hour (12 times.) mongostat
(page 624) collects data from the mongod (page 555) instance running on the localhost interface on port 27017. Both
of the following invocations produce identical behavior.
mongostat --rowcount 12 300
mongostat -n 12 300
In many cases, using the --discover will help provide a more complete snapshot of the state of an entire group
of machines. If a mongos (page 571) process connected to a sharded cluster is running on port 27017 of the local
machine, you can use the following form to return statistics from all members of the cluster:
mongostat --discover
4.1. MongoDB Package Components 629
MongoDB Reference Manual, Release 2.6.4
mongotop
Synopsis
mongotop (page 630) provides a method to track the amount of time a MongoDBinstance spends reading and writing
data. mongotop (page 630) provides statistics on a per-collection level. By default, mongotop (page 630) returns
values every second.
Important: In order to connect to a mongod (page 555) that enforces authorization with the --auth option, the
--username and --password options must be used, and the user specied must have the serverStatus and
top privileges.
The most appropriate built-in role that has these privileges is clusterMonitor.
See also:
For more information about monitoring MongoDB, see http://docs.mongodb.org/manualadministration/monitoring.
For additional background on various other MongoDB status outputs see:
serverStatus (page 354)
replSetGetStatus (page 289)
dbStats (page 342)
collStats (page 338)
For an additional utility that provides MongoDB metrics see mongostat (page 623).
Options
mongotop
mongotop
command line option!help
--help
Returns information on the options and use of mongotop (page 630).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongotop (page 630) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
630 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--version
Returns the mongotop (page 630) release number.
command line option!host <hostname><:port>, -h
--host <hostname><:port>, -h
Default: localhost:27017
Species a resolvable hostname for the mongod (page 555) to which to connect. By default, the mongotop
(page 630) attempts to connect to a MongoDB instance running on the localhost on port number 27017.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
You can always connect directly to a single MongoDB instance by specifying the host and port number directly.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
--ipv6
Enables IPv6 support and allows the mongotop (page 630) to connect to the MongoDB instance using an IPv6
network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
4.1. MongoDB Package Components 631
MongoDB Reference Manual, Release 2.6.4
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongotop (page 630) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongotop (page 630) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongotop (page 630) to use the FIPS mode of the installed OpenSSL library. Your system must
have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
632 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentica-
tion database, the mongotop (page 630) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongotop (page 630) instance uses to authenticate to the mongod
(page 555) or mongos (page 571).
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
42
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
43
.
command line option!locks
--locks
Toggles the mode of mongotop (page 630) to report on use of per-database locks (page 355). These data are
useful for measuring concurrent operations and lock percentage.
<sleeptime>
The nal argument is the length of time, in seconds, that mongotop (page 630) waits in between calls. By
default mongotop (page 630) returns data every second.
Fields
mongotop (page 630) returns time values specied in milliseconds (ms.)
mongotop (page 630) only reports active namespaces or databases, depending on the --locks (page 633) option.
If you dont see a database or collection, it has received no recent activity. You can issue a simple operation in the
mongo (page 580) shell to generate activity to affect the output of mongotop (page 630).
mongotop.ns
Contains the database namespace, which combines the database name and collection.
40
http://www.mongodb.com/products/mongodb-enterprise
41
http://www.mongodb.com/products/mongodb-enterprise
42
http://www.mongodb.com/products/mongodb-enterprise
43
http://www.mongodb.com/products/mongodb-enterprise
4.1. MongoDB Package Components 633
MongoDB Reference Manual, Release 2.6.4
Changed in version 2.2: If you use the --locks (page 633), the ns (page 633) eld does not appear in the
mongotop (page 630) output.
mongotop.db
New in version 2.2.
Contains the name of the database. The database named . refers to the global lock, rather than a specic
database.
This eld does not appear unless you have invoked mongotop (page 630) with the --locks (page 633)
option.
mongotop.total
Provides the total amount of time that this mongod (page 555) spent operating on this namespace.
mongotop.read
Provides the amount of time that this mongod (page 555) spent performing read operations on this namespace.
mongotop.write
Provides the amount of time that this mongod (page 555) spent performing write operations on this namespace.
mongotop.<timestamp>
Provides a time stamp for the returned data.
Use
By default mongotop (page 630) connects to the MongoDB instance running on the localhost port 27017. However,
mongotop (page 630) can optionally connect to remote mongod (page 555) instances. See the mongotop options
(page 630) for more information.
To force mongotop (page 630) to return less frequently specify a number, in seconds at the end of the command. In
this example, mongotop (page 630) will return every 15 seconds.
mongotop 15
This command produces the following output:
connected to: 127.0.0.1
ns total read write 2012-08-13T15:45:40
test.system.namespaces 0ms 0ms 0ms
local.system.replset 0ms 0ms 0ms
local.system.indexes 0ms 0ms 0ms
admin.system.indexes 0ms 0ms 0ms
admin. 0ms 0ms 0ms
ns total read write 2012-08-13T15:45:55
test.system.namespaces 0ms 0ms 0ms
local.system.replset 0ms 0ms 0ms
local.system.indexes 0ms 0ms 0ms
admin.system.indexes 0ms 0ms 0ms
admin. 0ms 0ms 0ms
To return a mongotop (page 630) report every 5 minutes, use the following command:
mongotop 300
To report the use of per-database locks, use mongotop --locks, which produces the following output:
634 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
$ mongotop --locks
connected to: 127.0.0.1
db total read write 2012-08-13T16:33:34
local 0ms 0ms 0ms
admin 0ms 0ms 0ms
. 0ms 0ms 0ms
mongosniff
Synopsis
mongosniff (page 635) provides a low-level operation tracing/snifng view into database activity in real time.
Think of mongosniff (page 635) as a MongoDB-specic analogue of tcpdump for TCP/IP network trafc. Typi-
cally, mongosniff (page 635) is most frequently used in driver development.
Note: mongosniff (page 635) requires libpcap and is only available for Unix-like systems. Furthermore, the
version distributed with the MongoDB binaries is dynamically linked against aversion 0.9 of libpcap. If your
system has a different version of libpcap, you will need to compile mongosniff (page 635) yourself or create a
symbolic link pointing to libpcap.so.0.9 to your local version of libpcap. Use an operation that resembles
the following:
ln -s /usr/lib/libpcap.so.1.1.1 /usr/lib/libpcap.so.0.9
Change the paths and name of the shared library as needed.
As an alternative to mongosniff (page 635), Wireshark, a popular network snifng tool is capable of inspecting and
parsing the MongoDB wire protocol.
Options
mongosniff
mongosniff
command line option!help
--help
Returns information on the options and use of mongosniff (page 635).
command line option!forward <host><:port>
--forward <host><:port>
Declares a host to forward all parsed requests that the mongosniff (page 635) intercepts to another mongod
(page 555) instance and issue those operations on that database instance.
Specify the target host name and port in the <host><:port> format.
To connect to a replica set, specify the replica set name and a seed list of set members. Use the following
form:
<replSetName>/<hostname1><:port>,<hostname2><:port>,<...>
command line option!source <NET [interface]>, <FILE [lename]>, <DIAGLOG [lename]>
4.1. MongoDB Package Components 635
MongoDB Reference Manual, Release 2.6.4
--source <NET [interface]>
Species source material to inspect. Use --source NET [interface] to inspect trafc from a network
interface (e.g. eth0 or lo.) Use --source FILE [filename] to read captured packets in pcap format.
You may use the --source DIAGLOG [filename] option to read the output les produced by the
--diaglog option.
command line option!objcheck
--objcheck
Displays invalid BSON objects only and nothing else. Use this option for troubleshooting driver development.
This option has some performance impact on the performance of mongosniff (page 635).
<port>
Species alternate ports to sniff for trafc. By default, mongosniff (page 635) watches for MongoDB trafc
on port 27017. Append multiple port numbers to the end of mongosniff (page 635) to monitor trafc on
multiple ports.
Use
Use the following command to connect to a mongod (page 555) or mongos (page 571) running on port 27017 and
27018 on the localhost interface:
mongosniff --source NET lo 27017 27018
Use the following command to only log invalid BSON objects for the mongod (page 555) or mongos (page 571)
running on the localhost interface and port 27018, for driver development and troubleshooting:
mongosniff --objcheck --source NET lo 27018
Build mongosniff
To build mongosniff yourself, Linux users can use the following procedure:
1. Obtain prerequisites using your operating systems package management software. Dependencies include:
libpcap - to capture network packets.
git - to download the MongoDB source code.
scons and a C++ compiler - to build mongosniff (page 635).
2. Download a copy of the MongoDB source code using git:
git clone git://github.com/mongodb/mongo.git
3. Issue the following sequence of commands to change to the mongo/ directory and build mongosniff
(page 635):
cd mongo
scons mongosniff
Note: If you run scons mongosniff before installing libpcap you must run scons clean before you can
build mongosniff (page 635).
636 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
mongoperf
Synopsis
mongoperf (page 637) is a utility to check disk I/O performance independently of MongoDB.
It times tests of random disk I/O and presents the results. You can use mongoperf (page 637) for any case apart
from MongoDB. The mmf (page 638) true mode is completely generic. In that mode it is somewhat analogous to
tools such as bonnie++
44
(albeit mongoperf is simpler).
Specify options to mongoperf (page 637) using a JavaScript document.
See also:
bonnie
45
bonnie++
46
Output from an example run
47
Checking Disk Performance with the mongoperf Utility
48
Options
mongoperf
mongoperf
command line option!help, -h
--help, -h
Returns information on the options and use of mongoperf (page 637).
<jsonconfig>
mongoperf (page 637) accepts conguration options in the form of a le that holds a JSON document. You
must stream the content of this le into mongoperf (page 637), as in the following operation:
mongoperf < config
In this example config is the name of a le that holds a JSON document that resembles the following example:
{
nThreads:<n>,
fileSizeMB:<n>,
sleepMicros:<n>,
mmf:<bool>,
r:<bool>,
w:<bool>,
recSizeKB:<n>,
syncDelay:<n>
}
See the Conguration Fields (page 638) section for documentation of each of these elds.
44
http://sourceforge.net/projects/bonnie/
45
http://www.textuality.com/bonnie/
46
http://sourceforge.net/projects/bonnie/
47
https://gist.github.com/1694664
48
http://blog.mongodb.org/post/40769806981/checking-disk-performance-with-the-mongoperf-utility
4.1. MongoDB Package Components 637
MongoDB Reference Manual, Release 2.6.4
Conguration Fields
mongoperf.nThreads
Type: Integer.
Default: 1
Denes the number of threads mongoperf (page 637) will use in the test. To saturate your systems storage
system you will need multiple threads. Consider setting nThreads (page 638) to 16.
mongoperf.fileSizeMB
Type: Integer.
Default: 1 megabyte (i.e. 1024
2
bytes)
Test le size.
mongoperf.sleepMicros
Type: Integer.
Default: 0
mongoperf (page 637) will pause for the number of specied sleepMicros (page 638) divided by the
nThreads (page 638) between each operation.
mongoperf.mmf
Type: Boolean.
Default: false
Set mmf (page 638) to true to use memory mapped les for the tests.
Generally:
when mmf (page 638) is false, mongoperf (page 637) tests direct, physical, I/O, without caching. Use
a large le size to test heavy random I/O load and to avoid I/O coalescing.
when mmf (page 638) is true, mongoperf (page 637) runs tests of the caching system, and can use
normal le system cache. Use mmf (page 638) in this mode to test le system cache behavior with memory
mapped les.
mongoperf.r
Type: Boolean.
Default: false
Set r (page 638) to true to perform reads as part of the tests.
Either r (page 638) or w (page 638) must be true.
mongoperf.w
Type: Boolean.
Default: false
Set w (page 638) to true to perform writes as part of the tests.
Either r (page 638) or w (page 638) must be true.
mongoperf.recSizeKB
New in version 2.4.
Type: Integer.
Default: 4 kb
The size of each write operation.
638 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
mongoperf.syncDelay
Type: Integer.
Default: 0
Seconds between disk ushes. mongoperf.syncDelay (page 639) is similar to --syncdelay for
mongod (page 555).
The syncDelay (page 639) controls how frequently mongoperf (page 637) performs an asynchronous disk
ush of the memory mapped le used for testing. By default, mongod (page 555) performs this operation every
60 seconds. Use syncDelay (page 639) to test basic system performance of this type of operation.
Only use syncDelay (page 639) in conjunction with mmf (page 638) set to true.
The default value of 0 disables this.
Use
mongoperf < jsonconfigfile
Replace jsonconfigfile with the path to the mongoperf (page 637) conguration. You may also invoke
mongoperf (page 637) in the following form:
echo "{nThreads:16,fileSizeMB:1000,r:true}" | ./mongoperf
In this operation:
mongoperf (page 637) tests direct physical random read ios, using 16 concurrent reader threads.
mongoperf (page 637) uses a 1 gigabyte test le.
Consider using iostat, as invoked in the following example to monitor I/O performance during the test.
iostat -xtm 1
4.1.6 GridFS
mongofiles (page 639) provides a command-line interact to a MongoDB GridFS storage system.
mongofiles
mongofiles
Synopsis
The mongofiles (page 639) utility makes it possible to manipulate les stored in your MongoDBinstance in GridFS
objects from the command line. It is particularly useful as it provides an interface between objects stored in your le
system and GridFS.
All mongofiles (page 639) commands have the following form:
mongofiles <options> <commands> <filename>
The components of the mongofiles (page 639) command are:
1. Options (page 640). You may use one or more of these options to control the behavior of mongofiles
(page 639).
4.1. MongoDB Package Components 639
MongoDB Reference Manual, Release 2.6.4
2. Commands (page 644). Use one of these commands to determine the action of mongofiles (page 639).
3. A lename which is either: the name of a le on your locals le system, or a GridFS object.
mongofiles (page 639), like mongodump (page 590), mongoexport (page 616), mongoimport (page 610),
and mongorestore (page 597), can access data stored in a MongoDB data directory without requiring a running
mongod (page 555) instance, if no other mongod (page 555) is running.
Important: For replica sets, mongofiles (page 639) can only read from the sets primary.
Options
mongofiles
command line option!help
--help
Returns information on the options and use of mongofiles (page 639).
command line option!verbose, -v
--verbose, -v
Increases the amount of internal reporting returned on standard output or in log les. Increase the verbosity with
the -v form by including the option multiple times, (e.g. -vvvvv.)
command line option!quiet
--quiet
Runs the mongofiles (page 639) in a quiet mode that attempts to limit the amount of output.
This option suppresses:
output from database commands
replication activity
connection accepted events
connection closed events
command line option!version
--version
Returns the mongofiles (page 639) release number.
command line option!host <hostname><:port>
--host <hostname><:port>
Species a resolvable hostname for the mongod (page 555) that holds your GridFS system. By default
mongofiles (page 639) attempts to connect to a MongoDB process running on the localhost port number
27017.
Optionally, specify a port number to connect a MongoDB instance running on a port other than 27017.
command line option!port <port>
--port <port>
Default: 27017
Species the TCP port on which the MongoDB instance listens for client connections.
command line option!ipv6
640 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
--ipv6
Enables IPv6 support and allows the mongofiles (page 639) to connect to the MongoDB instance using an
IPv6 network. All MongoDB programs and processes disable IPv6 support by default.
command line option!ssl
--ssl
New in version 2.6.
Enables connection to a mongod (page 555) or mongos (page 571) that has SSL support enabled.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCAFile <lename>
--sslCAFile <filename>
New in version 2.6.
Species the .pem le that contains the root certicate chain from the Certicate Authority. Specify the le
name of the .pem le using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
Warning: If the mongo (page 580) shell or any other tool that connects to mongos (page 571) or mongod
(page 555) is run without --sslCAFile, it will not attempt to validate server certicates. This results in
vulnerability to expired mongod (page 555) and mongos (page 571) certicates as well as to foreign pro-
cesses posing as valid mongod (page 555) or mongos (page 571) instances. Ensure that you always specify
the CA le against which server certicates should be validated in cases where intrusion is a possibility.
command line option!sslPEMKeyFile <lename>
--sslPEMKeyFile <filename>
New in version 2.6.
Species the .pem le that contains both the SSL certicate and key. Specify the le name of the .pem le
using relative or absolute paths.
This option is required when using the --ssl (page 631) option to connect to a mongod (page 555) or mongos
(page 571) that has CAFile enabled without weakCertificateValidation.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslPEMKeyPassword <value>
--sslPEMKeyPassword <value>
New in version 2.6.
Species the password to de-crypt the certicate-key le (i.e. --sslPEMKeyFile (page 631)). Use the
--sslPEMKeyPassword (page 632) option only if the certicate-key le is encrypted. In all cases, the
mongofiles (page 639) will redact the password from all logging and reporting output.
If the private key in the PEM le is encrypted and you do not specify the --sslPEMKeyPassword (page 632)
option, the mongofiles (page 639) will prompt for a passphrase. See ssl-certicate-password.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslCRLFile <lename>
4.1. MongoDB Package Components 641
MongoDB Reference Manual, Release 2.6.4
--sslCRLFile <filename>
New in version 2.6.
Species the .pem le that contains the Certicate Revocation List. Specify the le name of the .pem le
using relative or absolute paths.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslAllowInvalidCerticates
--sslAllowInvalidCertificates
New in version 2.6.
Bypasses the validation checks for server certicates and allows the use of invalid certicates. When using the
allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid certicate.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!sslFIPSMode
--sslFIPSMode
New in version 2.6.
Directs the mongofiles (page 639) to use the FIPS mode of the installed OpenSSL library. Your system must
have a FIPS compliant OpenSSL library to use the --sslFIPSMode (page 632) option.
The default distribution of MongoDB does not contain support for SSL. For more information on MongoDB
and SSL, see http://docs.mongodb.org/manualtutorial/configure-ssl.
command line option!username <username>, -u
--username <username>, -u
Species a username with which to authenticate to a MongoDB database that uses authentication. Use in
conjunction with the --password and --authenticationDatabase options.
command line option!password <password>, -p
--password <password>, -p
Species a password with which to authenticate to a MongoDB database that uses authentication. Use in con-
junction with the --username and --authenticationDatabase options.
command line option!authenticationDatabase <dbname>
--authenticationDatabase <dbname>
New in version 2.4.
Species the database that holds the users credentials. If you do not specify an authentica-
tion database, the mongofiles (page 639) assumes that the database specied as the argument to
--authenticationDatabase (page 633) holds the users credentials.
command line option!authenticationMechanism <name>
--authenticationMechanism <name>
Default: MONGODB-CR
New in version 2.4.
Changed in version 2.6: Added support for the PLAIN and MONGODB-X509 authentication mechanisms.
Species the authentication mechanism the mongofiles (page 639) instance uses to authenticate to the
mongod (page 555) or mongos (page 571).
642 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
Value Description
MONGODB-
CR
MongoDB challenge/response authentication.
MONGODB-
X509
MongoDB SSL certicate authentication.
PLAIN External authentication using LDAP. You can also use PLAIN for authenticating in-database
users. PLAIN transmits passwords in plain text. This mechanism is available only in
MongoDB Enterprise
51
.
GSSAPI External authentication using Kerberos. This mechanism is available only in MongoDB
Enterprise
52
.
command line option!dbpath <path>
--dbpath <path>
Species the directory of the MongoDB data les. The --dbpath (page 600) option lets the mongofiles
(page 639) attach directly to the local data les without going through a running mongod (page 555). When
run with --dbpath (page 600), the mongofiles (page 639) locks access to the data les. No mongod
(page 555) can access the les while the mongofiles (page 639) process runs.
command line option!directoryperdb
--directoryperdb
When used in conjunction with the corresponding option in mongod (page 555), allows the mongofiles
(page 639) to access data from MongoDB instances that use an on-disk format where every database has a
distinct directory. This option is only relevant when specifying the --dbpath (page 600) option.
command line option!journal
--journal
Enables the durability journal to ensure data les remain valid and recoverable. This option applies only when
you specify the --dbpath (page 600) option. The mongofiles (page 639) enables journaling by default on
64-bit builds of versions after 2.0.
command line option!db <database>, -d
--db <database>, -d
Species the name of the database on which to run the mongofiles (page 639).
command line option!collection <collection>, -c
--collection <collection>, -c
This option has no use in this context and a future release may remove it. See SERVER-4931
53
for more
information.
command line option!local <lename>, -l
--local <filename>, -l
Species the local lesystem name of a le for get and put operations.
In the mongoles put and mongoles get commands, the required <filename> modier refers to the name
the object will have in GridFS. mongofiles (page 639) assumes that this reects the les name on the local
le system. This setting overrides this default.
command line option!type <MIME>
49
http://www.mongodb.com/products/mongodb-enterprise
50
http://www.mongodb.com/products/mongodb-enterprise
51
http://www.mongodb.com/products/mongodb-enterprise
52
http://www.mongodb.com/products/mongodb-enterprise
53
https://jira.mongodb.org/browse/SERVER-4931
4.1. MongoDB Package Components 643
MongoDB Reference Manual, Release 2.6.4
--type <MIME>
Provides the ability to specify a MIME type to describe the le inserted into GridFS storage. mongofiles
(page 639) omits this option in the default operation.
Use only with mongoles put operations.
command line option!replace, -r
--replace, -r
Alters the behavior of mongoles put to replace existing GridFS objects with the specied local le, rather than
adding an additional object with the same name.
In the default operation, les will not be overwritten by a mongoles put option.
Commands
list <prefix>
Lists the les in the GridFS store. The characters specied after list (e.g. <prefix>) optionally limit the
list of returned items to les that begin with that string of characters.
search <string>
Lists the les in the GridFS store with names that match any portion of <string>.
put <filename>
Copy the specied le from the local le system into GridFS storage.
Here, <filename> refers to the name the object will have in GridFS, and mongofiles (page 639) as-
sumes that this reects the name the le has on the local le system. If the local lename is different use the
mongofiles --local option.
get <filename>
Copy the specied le from GridFS storage to the local le system.
Here, <filename> refers to the name the object will have in GridFS, and mongofiles (page 639) as-
sumes that this reects the name the le has on the local le system. If the local lename is different use the
mongofiles --local option.
delete <filename>
Delete the specied le from GridFS storage.
Examples
To return a list of all les in a GridFS collection in the records database, use the following invocation at the system
shell:
mongofiles -d records list
This mongofiles (page 639) instance will connect to the mongod (page 555) instance running on the 27017
localhost interface to specify the same operation on a different port or hostname, and issue a command that resembles
one of the following:
mongofiles --port 37017 -d records list
mongofiles --hostname db1.example.net -d records list
mongofiles --hostname db1.example.net --port 37017 -d records list
Modify any of the following commands as needed if youre connecting the mongod (page 555) instances on different
ports or hosts.
644 Chapter 4. Program and Tool Reference Pages
MongoDB Reference Manual, Release 2.6.4
To upload a le named 32-corinth.lp to the GridFS collection in the records database, you can use the
following command:
mongofiles -d records put 32-corinth.lp
To delete the 32-corinth.lp le from this GridFS collection in the records database, you can use the following
command:
mongofiles -d records delete 32-corinth.lp
To search for les in the GridFS collection in the records database that have the string corinth in their names,
you can use following command:
mongofiles -d records search corinth
To list all les in the GridFS collection in the records database that begin with the string 32, you can use the
following command:
mongofiles -d records list 32
To fetch the le from the GridFS collection in the records database named 32-corinth.lp, you can use the
following command:
mongofiles -d records get 32-corinth.lp
4.1. MongoDB Package Components 645
MongoDB Reference Manual, Release 2.6.4
646 Chapter 4. Program and Tool Reference Pages
CHAPTER 5
Internal Metadata
5.1 Cong Database
The config database supports sharded cluster operation. See the http://docs.mongodb.org/manualsharding
section of this manual for full documentation of sharded clusters.
Important: Consider the schema of the config database internal and may change between releases of MongoDB.
The config database is not a dependable API, and users should not write data to the config database in the course
of normal operation or maintenance.
Warning: Modication of the config database on a functioning system may lead to instability or inconsistent
data sets. If you must modify the config database, use mongodump (page 590) to create a full backup of the
config database.
To access the config database, connect to a mongos (page 571) instance in a sharded cluster, and use the following
helper:
use config
You can return a list of the collections, with the following helper:
show collections
5.1.1 Collections
config
config.changelog
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The changelog (page 647) collection stores a document for each change to the metadata of a sharded collec-
tion.
Example
647
MongoDB Reference Manual, Release 2.6.4
The following example displays a single record of a chunk split from a changelog (page 647) collection:
{
"_id" : "<hostname>-<timestamp>-<increment>",
"server" : "<hostname><:port>",
"clientAddr" : "127.0.0.1:63381",
"time" : ISODate("2012-12-11T14:09:21.039Z"),
"what" : "split",
"ns" : "<database>.<collection>",
"details" : {
"before" : {
"min" : {
"<database>" : { $minKey : 1 }
},
"max" : {
"<database>" : { $maxKey : 1 }
},
"lastmod" : Timestamp(1000, 0),
"lastmodEpoch" : ObjectId("000000000000000000000000")
},
"left" : {
"min" : {
"<database>" : { $minKey : 1 }
},
"max" : {
"<database>" : "<value>"
},
"lastmod" : Timestamp(1000, 1),
"lastmodEpoch" : ObjectId(<...>)
},
"right" : {
"min" : {
"<database>" : "<value>"
},
"max" : {
"<database>" : { $maxKey : 1 }
},
"lastmod" : Timestamp(1000, 2),
"lastmodEpoch" : ObjectId("<...>")
}
}
}
Each document in the changelog (page 647) collection contains the following elds:
config.changelog._id
The value of changelog._id is: <hostname>-<timestamp>-<increment>.
config.changelog.server
The hostname of the server that holds this data.
config.changelog.clientAddr
A string that holds the address of the client, a mongos (page 571) instance that initiates this change.
config.changelog.time
A ISODate timestamp that reects when the change occurred.
config.changelog.what
Reects the type of change recorded. Possible values are:
648 Chapter 5. Internal Metadata
MongoDB Reference Manual, Release 2.6.4
dropCollection
dropCollection.start
dropDatabase
dropDatabase.start
moveChunk.start
moveChunk.commit
split
multi-split
config.changelog.ns
Namespace where the change occurred.
config.changelog.details
A document that contains additional details regarding the change. The structure of the details
(page 649) document depends on the type of change.
config.chunks
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The chunks (page 649) collection stores a document for each chunk in the cluster. Consider the following
example of a document for a chunk named records.pets-animal_\"cat\":
{
"_id" : "mydb.foo-a_\"cat\"",
"lastmod" : Timestamp(1000, 3),
"lastmodEpoch" : ObjectId("5078407bd58b175c5c225fdc"),
"ns" : "mydb.foo",
"min" : {
"animal" : "cat"
},
"max" : {
"animal" : "dog"
},
"shard" : "shard0004"
}
These documents store the range of values for the shard key that describe the chunk in the min and max elds.
Additionally the shard eld identies the shard in the cluster that owns the chunk.
config.collections
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The collections (page 649) collection stores a document for each sharded collection in the cluster. Given
a collection named pets in the records database, a document in the collections (page 649) collection
would resemble the following:
5.1. Cong Database 649
MongoDB Reference Manual, Release 2.6.4
{
"_id" : "records.pets",
"lastmod" : ISODate("1970-01-16T15:00:58.107Z"),
"dropped" : false,
"key" : {
"a" : 1
},
"unique" : false,
"lastmodEpoch" : ObjectId("5078407bd58b175c5c225fdc")
}
config.databases
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The databases (page 650) collection stores a document for each database in the cluster, and tracks if the
database has sharding enabled. databases (page 650) represents each database in a distinct document. When
a databases have sharding enabled, the primary eld holds the name of the primary shard.
{ "_id" : "admin", "partitioned" : false, "primary" : "config" }
{ "_id" : "mydb", "partitioned" : true, "primary" : "shard0000" }
config.lockpings
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The lockpings (page 650) collection keeps track of the active components in the sharded cluster. Given
a cluster with a mongos (page 571) running on example.com:30000, the document in the lockpings
(page 650) collection would resemble:
{ "_id" : "example.com:30000:1350047994:16807", "ping" : ISODate("2012-10-12T18:32:54.892Z") }
config.locks
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The locks (page 650) collection stores a distributed lock. This ensures that only one mongos (page 571)
instance can perform administrative tasks on the cluster at once. The mongos (page 571) acting as balancer
takes a lock by inserting a document resembling the following into the locks collection.
{
"_id" : "balancer",
"process" : "example.net:40000:1350402818:16807",
"state" : 2,
"ts" : ObjectId("507daeedf40e1879df62e5f3"),
"when" : ISODate("2012-10-16T19:01:01.593Z"),
650 Chapter 5. Internal Metadata
MongoDB Reference Manual, Release 2.6.4
"who" : "example.net:40000:1350402818:16807:Balancer:282475249",
"why" : "doing balance round"
}
If a mongos (page 571) holds the balancer lock, the state eld has a value of 2, which means that balancer
is active. The when eld indicates when the balancer began the current operation.
Changed in version 2.0: The value of the state eld was 1 before MongoDB 2.0.
config.mongos
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The mongos (page 651) collection stores a document for each mongos (page 571) instance afliated with the
cluster. mongos (page 571) instances send pings to all members of the cluster every 30 seconds so the cluster
can verify that the mongos (page 571) is active. The ping eld shows the time of the last ping, while the up
eld reports the uptime of the mongos (page 571) as of the last ping. The cluster maintains this collection for
reporting purposes.
The following document shows the status of the mongos (page 571) running on example.com:30000.
{ "_id" : "example.com:30000", "ping" : ISODate("2012-10-12T17:08:13.538Z"), "up" : 13699, "waiting" : true }
config.settings
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The settings (page 651) collection holds the following sharding conguration settings:
Chunk size. To change chunk size, see http://docs.mongodb.org/manualtutorial/modify-chunk-size-in-sharded-cluster.
Balancer status. To change status, see sharding-balancing-disable-temporarily.
The following is an example settings collection:
{ "_id" : "chunksize", "value" : 64 }
{ "_id" : "balancer", "stopped" : false }
config.shards
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The shards (page 651) collection represents each shard in the cluster in a separate document. If the shard
is a replica set, the host eld displays the name of the replica set, then a slash, then the hostname, as in the
following example:
{ "_id" : "shard0000", "host" : "shard1/localhost:30000" }
5.1. Cong Database 651
MongoDB Reference Manual, Release 2.6.4
If the shard has tags assigned, this document has a tags eld, that holds an array of the tags, as in the following
example:
{ "_id" : "shard0001", "host" : "localhost:30001", "tags": [ "NYC" ] }
config.tags
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The tags (page 652) collection holds documents for each tagged shard key range in the cluster. The documents
in the tags (page 652) collection resemble the following:
{
"_id" : { "ns" : "records.users", "min" : { "zipcode" : "10001" } },
"ns" : "records.users",
"min" : { "zipcode" : "10001" },
"max" : { "zipcode" : "10281" },
"tag" : "NYC"
}
config.version
Internal MongoDB Metadata
The config (page 647) database is internal: applications and administrators should not modify or depend upon
its content in the course of normal operation.
The version (page 652) collection holds the current metadata version number. This collection contains only
one document:
To access the version (page 652) collection you must use the db.getCollection() (page 116) method.
For example, to display the collections document:
mongos> db.getCollection("version").find()
{ "_id" : 1, "version" : 3 }
Note: Like all databases in MongoDB, the config database contains a system.indexes
(page 655) collection contains metadata for all indexes in the database for information on indexes, see
http://docs.mongodb.org/manualindexes.
5.2 The local Database
5.2.1 Overview
Every mongod (page 555) instance has its own local database, which stores data used in the replication process,
and other instance-specic data. The local database is invisible to replication: collections in the local database
are not replicated.
In replication, the local database store stores internal replication data for each member of a replica set. The local
stores the following collections:
652 Chapter 5. Internal Metadata
MongoDB Reference Manual, Release 2.6.4
Changed in version 2.4: When running with authentication (i.e. authorization), authenticating to the local
database is not equivalent to authenticating to the admin database. In previous versions, authenticating to the local
database provided access to all databases.
5.2.2 Collection on all mongod Instances
local.startup_log
On startup, each mongod (page 555) instance inserts a document into startup_log (page 653) with diagnos-
tic information about the mongod (page 555) instance itself and host information. startup_log (page 653)
is a capped collection. This information is primarily useful for diagnostic purposes.
Example
Consider the following prototype of a document from the startup_log (page 653) collection:
{
"_id" : "<string>",
"hostname" : "<string>",
"startTime" : ISODate("<date>"),
"startTimeLocal" : "<string>",
"cmdLine" : {
"dbpath" : "<path>",
"<option>" : <value>
},
"pid" : <number>,
"buildinfo" : {
"version" : "<string>",
"gitVersion" : "<string>",
"sysInfo" : "<string>",
"loaderFlags" : "<string>",
"compilerFlags" : "<string>",
"allocator" : "<string>",
"versionArray" : [ <num>, <num>, <...> ],
"javascriptEngine" : "<string>",
"bits" : <number>,
"debug" : <boolean>,
"maxBsonObjectSize" : <number>
}
}
Documents in the startup_log (page 653) collection contain the following elds:
local.startup_log._id
Includes the system hostname and a millisecond epoch value.
local.startup_log.hostname
The systems hostname.
local.startup_log.startTime
A UTC ISODate value that reects when the server started.
local.startup_log.startTimeLocal
A string that reports the startTime (page 653) in the systems local time zone.
local.startup_log.cmdLine
A sub-document that reports the mongod (page 555) runtime options and their values.
local.startup_log.pid
The process identier for this process.
5.2. The local Database 653
MongoDB Reference Manual, Release 2.6.4
local.startup_log.buildinfo
A sub-document that reports information about the build environment and settings used to compile this
mongod (page 555). This is the same output as buildInfo (page 336). See buildInfo (page 337).
5.2.3 Collections on Replica Set Members
local.system.replset
local.system.replset (page 654) holds the replica sets conguration object as its single document. To
view the objects conguration information, issue rs.conf() (page 173) from the mongo (page 580) shell.
You can also query this collection directly.
local.oplog.rs
local.oplog.rs (page 654) is the capped collection that holds the oplog. You set its size at
creation using the oplogSizeMB setting. To resize the oplog after replica set initiation, use the
http://docs.mongodb.org/manualtutorial/change-oplog-size procedure. For additional
information, see the replica-set-oplog-sizing section.
local.replset.minvalid
This contains an object used internally by replica sets to track replication status.
local.slaves
This contains information about each member of the set and the latest point in time that this member has synced
to. If this collection becomes out of date, you can refresh it by dropping the collection and allowing MongoDB
to automatically refresh it during normal replication:
db.getSiblingDB("local").slaves.drop()
5.2.4 Collections used in Master/Slave Replication
In master/slave replication, the local database contains the following collections:
On the master:
local.oplog.$main
This is the oplog for the master-slave conguration.
local.slaves
This contains information about each slave.
On each slave:
local.sources
This contains information about the slaves master server.
5.3 System Collections
5.3.1 Synopsis
MongoDB stores system information in collections that use the <database>.system.
*
namespace, which Mon-
goDB reserves for internal use. Do not create collections that begin with system.
MongoDB also stores some additional instance-local metadata in the local database (page 652), specically for repli-
cation purposes.
654 Chapter 5. Internal Metadata
MongoDB Reference Manual, Release 2.6.4
5.3.2 Collections
System collections include these collections stored in the admin database:
admin.system.roles
New in version 2.6.
The admin.system.roles (page 655) collection stores custom roles that administrators create and assign
to users to provide access to specic resources.
admin.system.users
Changed in version 2.6.
The admin.system.users (page 655) collection stores the users authentication credentials as well as any
roles assigned to the user. Users may dene authorization roles in the admin.system.roles (page 655)
collection.
admin.system.version
New in version 2.6.
Stores the schema version of the user credential documents.
System collections also include these collections stored directly in each database:
<database>.system.namespaces
The <database>.system.namespaces (page 655) collection contains information about all of the
databases collections. Additional namespace metadata exists in the database.ns les and is opaque to
database users.
<database>.system.indexes
The <database>.system.indexes (page 655) collection lists all the indexes in the database. Add and
remove data from this collection via the ensureIndex() (page 30) and dropIndex() (page 29)
<database>.system.profile
The <database>.system.profile (page 655) collection stores database proling information. For in-
formation on proling, see database-proling.
<database>.system.js
The <database>.system.js (page 655) collection holds special JavaScript code for use in server
side JavaScript. See http://docs.mongodb.org/manualtutorial/store-javascript-function-on-server
for more information.
5.3. System Collections 655
MongoDB Reference Manual, Release 2.6.4
656 Chapter 5. Internal Metadata
CHAPTER 6
General System Reference
6.1 Exit Codes and Statuses
MongoDB will return one of the following codes and statuses when exiting. Use this guide to interpret logs and when
troubleshooting issues with mongod (page 555) and mongos (page 571) instances.
0
Returned by MongoDB applications upon successful exit.
2
The specied options are in error or are incompatible with other options.
3
Returned by mongod (page 555) if there is a mismatch between hostnames specied on the command line
and in the local.sources (page 654) collection. mongod (page 555) may also return this status if oplog
collection in the local database is not readable.
4
The version of the database is different fromthe version supported by the mongod (page 555) (or mongod.exe
(page 587)) instance. The instance exits cleanly. Restart mongod (page 555) with the --upgrade option to
upgrade the database to the version supported by this mongod (page 555) instance.
5
Returned by mongod (page 555) if a moveChunk (page 303) operation fails to conrm a commit.
12
Returned by the mongod.exe (page 587) process on Windows when it receives a Control-C, Close, Break or
Shutdown event.
14
Returned by MongoDBapplications which encounter an unrecoverable error, an uncaught exception or uncaught
signal. The system exits without performing a clean shut down.
20
Message: ERROR: wsastartup failed <reason>
Returned by MongoDB applications on Windows following an error in the WSAStartup function.
Message: NT Service Error
Returned by MongoDB applications for Windows due to failures installing, starting or removing the NT Service
for the application.
45
Returned when a MongoDB application cannot open a le or cannot obtain a lock on a le.
657
MongoDB Reference Manual, Release 2.6.4
47
MongoDB applications exit cleanly following a large clock skew (32768 milliseconds) event.
48
mongod (page 555) exits cleanly if the server socket closes. The server socket is on port 27017 by default, or
as specied to the --port run-time option.
49
Returned by mongod.exe (page 587) or mongos.exe (page 588) on Windows when either receives a shut-
down message from the Windows Service Control Manager.
100
Returned by mongod (page 555) when the process throws an uncaught exception.
6.2 MongoDB Limits and Thresholds
This document provides a collection of hard and soft limitations of the MongoDB system.
6.2.1 BSON Documents
BSON Document Size
The maximum BSON document size is 16 megabytes.
The maximum document size helps ensure that a single document cannot use excessive amount of RAM or,
during transmission, excessive amount of bandwidth. To store documents larger than the maximum size, Mon-
goDB provides the GridFS API. See mongofiles (page 639) and the documentation for your driver for
more information about GridFS.
Nested Depth for BSON Documents
Changed in version 2.2.
MongoDB supports no more than 100 levels of nesting for BSON documents.
6.2.2 Namespaces
Namespace Length
Each namespace, including database and collection name, must be shorter than 123 bytes.
Number of Namespaces
The limitation on the number of namespaces is the size of the namespace le divided by 628.
A 16 megabyte namespace le can support approximately 24,000 namespaces. Each collection and index is a
namespace.
Size of Namespace File
Namespace les can be no larger than 2047 megabytes.
By default namespace les are 16 megabytes. You can congure the size using the nsSize option.
6.2.3 Indexes
Index Key Limit
The total size of an index entry, which can include structural overhead depending on the BSON type, must be
less than 1024 bytes.
658 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
Changed in version 2.6: MongoDB 2.6 implements a stronger enforcement of the limit on index key
(page 658):
MongoDB will not create an index (page 30) on a collection if the index entry for an existing
document exceeds the index key limit (page 658). Previous versions of MongoDB would create
the index but not index such documents.
Reindexing operations will error if the index entry for an indexed eld exceeds the index key limit
(page 658). Reindexing operations occur as part of compact (page 316) and repairDatabase
(page 332) commands as well as the db.collection.reIndex() (page 63) method.
Because these operations drop all the indexes from a collection and then recreate them sequentially, the
error from the index key limit (page 658) prevents these operations from rebuilding any remain-
ing indexes for the collection and, in the case of the repairDatabase (page 332) command, from
continuing with the remainder of the process.
MongoDB will not insert into an indexed collection any document with an indexed eld whose corre-
sponding index entry would exceed the index key limit (page 658), and instead, will return an
error. Previous versions of MongoDB would insert but not index such documents.
Updates to the indexed eld will error if the updated value causes the index entry to exceed the index
key limit (page 658).
If an existing document contains an indexed eld whose index entry exceeds the limit, any update that
results in the relocation of that document on disk will error.
mongorestore (page 597) and mongoimport (page 610) will not insert documents that contain an
indexed eld whose corresponding index entry would exceed the index key limit (page 658).
In MongoDB 2.6, secondary members of replica sets will continue to replicate documents with an indexed
eld whose corresponding index entry exceeds the index key limit (page 658) on initial sync but
will print warnings in the logs.
Secondary members also allow index build and rebuild operations on a collection that contains an indexed
eld whose corresponding index entry exceeds the index key limit (page 658) but with warnings in
the logs.
With mixed version replica sets where the secondaries are version 2.6 and the primary is version 2.4,
secondaries will replicate documents inserted or updated on the 2.4 primary, but will print error messages
in the log if the documents contain an indexed eld whose corresponding index entry exceeds the index
key limit (page 658).
For existing sharded collections, chunk migration will fail if the chunk has a document that contains
an indexed eld whose index entry exceeds the index key limit (page 658).
Number of Indexes per Collection
A single collection can have no more than 64 indexes.
Index Name Length
Fully qualied index names, which includes the namespace and the dot separators (i.e. <database
name>.<collection name>.$<index name>), cannot be longer than 128 characters.
By default, <index name> is the concatenation of the eld names and index type. You can explicitly specify
the <index name> to the ensureIndex() (page 30) method to ensure that the fully qualied index name
does not exceed the limit.
Number of Indexed Fields in a Compound Index
There can be no more than 31 elds in a compound index.
Queries cannot use both text and Geospatial Indexes
You cannot combine the text (page 248) command, which requires a special text index, with a query operator
6.2. MongoDB Limits and Thresholds 659
MongoDB Reference Manual, Release 2.6.4
that requires a different type of special index. For example you cannot combine text (page 248) command
with the $near (page 410) operator.
See also:
The unique indexes limit in Sharding Operational Restrictions (page 661).
6.2.4 Data
Maximum Number of Documents in a Capped Collection
Changed in version 2.4.
If you specify a maximum number of documents for a capped collection using the max parameter to create
(page 326), the limit must be less than 2
32
documents. If you do not specify a maximum number of documents
when creating a capped collection, there is no limit on the number of documents.
Data Size
A single mongod (page 555) instance cannot manage a data set that exceeds maximum virtual memory address
space provided by the underlying operating system.
Table 6.1: Virtual Memory Limitations
Operating System Journaled Not Journaled
Linux 64 terabytes 128 terabytes
Windows Server 2012 R2 and Windows 8.1 64 terabytes 128 terabytes
Windows (otherwise) 4 terabytes 8 terabytes
Number of Collections in a Database
The maximum number of collections in a database is a function of the size of the namespace le and the number
of indexes of collections in the database.
See Number of Namespaces (page 658) for more information.
6.2.5 Replica Sets
Number of Members of a Replica Set
Replica sets can have no more than 12 members.
Number of Voting Members of a Replica Set
Only 7 members of a replica set can have votes at any given time. See can vote replica-set-non-voting-members
for more information
Maximum Size of Auto-Created Oplog
Changed in version 2.6.
If you do not explicitly specify an oplog size (i.e. with oplogSizeMB or --oplogSize) MongoDB will
create an oplog that is no larger than 50 gigabytes.
6.2.6 Sharded Clusters
Sharded clusters have the restrictions and thresholds described here.
660 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
Sharding Operational Restrictions
Operations Unavailable in Sharded Environments
The group (page 214) does not work with sharding. Use mapReduce (page 218) or aggregate (page 208)
instead.
db.eval() (page 113) is incompatible with sharded collections. You may use db.eval() (page 113) with
un-sharded collections in a shard cluster.
$where (page 404) does not permit references to the db object from the $where (page 404) function. This is
uncommon in un-sharded collections.
The $isolated (page 456) update modier does not work in sharded environments.
$snapshot (page 534) queries do not work in sharded environments.
The geoSearch (page 231) command is not supported in sharded environments.
Covered Queries in Sharded Clusters
MongoDB does not support covered queries for sharded collections.
Sharding Existing Collection Data Size
For existing collections that hold documents, MongoDB supports enabling sharding on any collections that
contains less than 256 gigabytes of data. MongoDB may be able to shard collections with as many as 400
gigabytes depending on the distribution of document sizes. The precise size of the limitation is a function of the
chunk size and the data size.
Important: Sharded collections may have any size, after successfully enabling sharding.
Single Document Modification Operations in Sharded Collections
All update() (page 70) and remove() (page 64) operations for a sharded collection that specify the
justOne or multi: false option must include the shard key or the _id eld in the query specica-
tion. update() (page 70) and remove() (page 64) operations specifying justOne or multi: false
in a sharded collection without the shard key or the _id eld return an error.
Unique Indexes in Sharded Collections
MongoDB does not support unique indexes across shards, except when the unique index contains the full shard
key as a prex of the index. In these situations MongoDB will enforce uniqueness across the full key, not a
single eld.
See
http://docs.mongodb.org/manualtutorial/enforce-unique-keys-for-sharded-collections
for an alternate approach.
Shard Key Limitations
Shard Key Size
A shard key cannot exceed 512 bytes.
Shard Key Index Type
A shard key index can be an ascending index on the shard key, a compound index that start with the shard key
and specify ascending order for the shard key, or a hashed index.
A shard key index cannot be an index that species a multikey index, a text index or a geospatial
index on the shard key elds.
6.2. MongoDB Limits and Thresholds 661
MongoDB Reference Manual, Release 2.6.4
Shard Key is Immutable
You cannot change a shard key after sharding the collection. If you must change a shard key:
Dump all data from MongoDB into an external format.
Drop the original sharded collection.
Congure sharding using the new shard key.
Pre-split the shard key range to ensure initial even distribution.
Restore the dumped data into MongoDB.
Shard Key Value in a Document is Immutable
After you insert a document into a sharded collection, you cannot change the documents value for the eld or
elds that comprise the shard key. The update() (page 70) operation will not modify the value of a shard key
in an existing document.
Monotonically Increasing Shard Keys Can Limit Insert Throughput
For clusters with high insert volumes, a shard keys with monotonically increasing and decreasing keys can
affect insert throughput. If your shard key is the _id eld, be aware that the default values of the _id elds are
ObjectIds which have generally increasing values.
When inserting documents with monotonically increasing shard keys, all inserts belong to the same chunk on a
single shard. The system will eventually divide the chunk range that receives all write operations and migrate
its contents to distribute data more evenly. However, at any moment the cluster can direct insert operations only
to a single shard, which creates an insert throughput bottleneck.
If the operations on the cluster are predominately read operations and updates, this limitation may not affect the
cluster.
To avoid this constraint, use a hashed shard key or select a eld that does not increase or decrease monotonically.
Changed in version 2.4: Hashed shard keys and hashed indexes store hashes of keys with ascending values.
6.2.7 Operations
Sorted Documents
MongoDB will only return sorted results on elds without an index if the sort operation uses less than 32
megabytes of memory.
Aggregation Pipeline Operation
Changed in version 2.6.
Pipeline stages have a limit of 100 megabytes of RAM. If a stage exceeds this limit, MongoDB will produce
an error. To allow for the handling of large datasets, use the allowDiskUse option to enable aggregation
pipeline stages to write data to temporary les.
See also:
$sort and Memory Restrictions (page 475) and $group Operator and Memory (page 461).
2d Geospatial queries cannot use the $or operator
See
$or (page 393) and http://docs.mongodb.org/manualcore/geospatial-indexes.
Spherical Polygons must fit within a hemisphere.
Any geometry specied with GeoJSON to $geoIntersects (page 406) or $geoWithin (page 407)
662 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
queries, must t within a single hemisphere. MongoDB interprets geometries larger than half of the sphere
as queries for the smaller of the complementary geometries.
Write Command Operation Limit Size
Write commands (page 232) can accept no more than 1000 operations. The Bulk() (page 135) operations in
the mongo (page 580) shell and comparable methods in the drivers do not have this limit.
6.2.8 Naming Restrictions
Database Name Case Sensitivity
MongoDB does not permit database names that differ only by the case of the characters.
Restrictions on Database Names for Windows
Changed in version 2.2: Restrictions on Database Names for Windows (page 739).
For MongoDB deployments running on Windows, MongoDB will not permit database names that include any
of the following characters:
/\. "
*
<>:|?
Also, database names cannot contain the null character.
Restrictions on Database Names for Unix and Linux Systems
For MongoDB deployments running on Unix and Linux systems, MongoDB will not permit database names
that include any of the following characters:
/\. "
Also, database names cannot contain the null character.
Length of Database Names
Database names cannot be empty and must have fewer than 64 characters.
Restriction on Collection Names
New in version 2.2.
Collection names should begin with an underscore or a letter character, and cannot:
contain the $.
be an empty string (e.g. "").
contain the null character.
begin with the system. prex. (Reserved for internal use.)
In the mongo (page 580) shell, use db.getCollection() (page 116) to specify collection names that might
interact with the shell or are not valid JavaScript.
Restrictions on Field Names
Field names cannot contain dots (i.e. .), dollar signs (i.e. $), or null characters. See faq-dollar-sign-escaping
for an alternate approach.
6.3 Glossary
$cmd A special virtual collection that exposes MongoDBs database commands. To use database commands, see
issue-commands.
6.3. Glossary 663
MongoDB Reference Manual, Release 2.6.4
_id A eld required in every MongoDB document. The _id eld must have a unique value. You can think of the
_id eld as the documents primary key. If you create a new document without an _id eld, MongoDB
automatically creates the eld and assigns a unique BSON ObjectId.
accumulator An expression in the aggregation framework that maintains state between documents in the aggregation
pipeline. For a list of accumulator operations, see $group (page 460).
action An operation the user can perform on a resource. Actions and resources combine to create privileges. See
action.
admin database A privileged database. Users must have access to the admin database to run certain administrative
commands. For a list of administrative commands, see Instance Administration Commands (page 312).
aggregation Any of a variety of operations that reduces and summarizes large sets of data. MongoDBs
aggregate() (page 22) and mapReduce() (page 56) methods are two examples of aggregation operations.
For more information, see http://docs.mongodb.org/manualcore/aggregation.
aggregation framework The set of MongoDB operators that let you calculate aggregate values without having to
use map-reduce. For a list of operators, see Aggregation Reference (page 536).
arbiter A member of a replica set that exists solely to vote in elections. Arbiters do not replicate data. See replica-
set-arbiter-conguration.
authentication Verication of the user identity. See http://docs.mongodb.org/manualcore/authentication.
authorization Provisioning of access to databases and operations. See
http://docs.mongodb.org/manualcore/authorization.
B-tree A data structure commonly used by database management systems to store indexes. MongoDB uses B-trees
for its indexes.
balancer An internal MongoDB process that runs in the context of a sharded cluster and manages the migration
of chunks. Administrators must disable the balancer for all maintenance operations on a sharded cluster. See
sharding-balancing.
BSON A serialization format used to store documents and make remote procedure calls in MongoDB. BSON is a
portmanteau of the words binary and JSON. Think of BSON as a binary representation of JSON (JavaScript
Object Notation) documents. See http://docs.mongodb.org/manualreference/bson-types
and http://docs.mongodb.org/manualreference/mongodb-extended-json.
BSON types The set of types supported by the BSON serialization format. For a list of BSON types, see
http://docs.mongodb.org/manualreference/bson-types.
CAP Theorem Given three properties of computing systems, consistency, availability, and partition tolerance, a
distributed computing system can provide any two of these features, but never all three.
capped collection A xed-sized collection that automatically overwrites its oldest entries when it reaches
its maximum size. The MongoDB oplog that is used in replication is a capped collection. See
http://docs.mongodb.org/manualcore/capped-collections.
checksum A calculated value used to ensure data integrity. The md5 algorithm is sometimes used as a checksum.
chunk A contiguous range of shard key values within a particular shard. Chunk ranges are inclusive of the
lower boundary and exclusive of the upper boundary. MongoDB splits chunks when they grow beyond
the congured chunk size, which by default is 64 megabytes. MongoDB migrates chunks when a shard
contains too many chunks of a collection relative to other shards. See sharding-data-partitioning and
http://docs.mongodb.org/manualcore/sharded-cluster-mechanics.
client The application layer that uses a database for data persistence and storage. Drivers provide the interface level
between the application layer and the database server.
cluster See sharded cluster.
664 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
collection Agrouping of MongoDB documents. Acollection is the equivalent of an RDBMS table. A collection exists
within a single database. Collections do not enforce a schema. Documents within a collection can have different
elds. Typically, all documents in a collection have a similar or related purpose. See faq-dev-namespace.
collection scan Collection scans are a query execution strategy where MongoDB must inspect every document in
a collection to see if it matches the query criteria. These queries are very inefcient and do not use indexes.
See http://docs.mongodb.org/manualcore/query-optimization for details about query ex-
ecution strategies.
compound index An index consisting of two or more keys. See index-type-compound.
cong database An internal database that holds the metadata associated with a sharded cluster. Applications and
administrators should not modify the config database in the course of normal operation. See Cong Database
(page 647).
cong server A mongod (page 555) instance that stores all the metadata associated with a sharded cluster. A
production sharded cluster requires three cong servers, each on a separate machine. See sharding-cong-
server.
control script A simple shell script, typically located in the /etc/rc.d or /etc/init.d directory, and used by
the systems initialization process to start, restart or stop a daemon process.
CRUD An acronym for the fundamental operations of a database: Create, Read, Update, and Delete. See
http://docs.mongodb.org/manualcrud.
CSV A text-based data format consisting of comma-separated values. This format is commonly used to exchange
data between relational databases since the format is well-suited to tabular data. You can import CSV les using
mongoimport (page 610).
cursor A pointer to the result set of a query. Clients can iterate through a cursor to retrieve results. By default,
cursors timeout after 10 minutes of inactivity. See read-operations-cursors.
daemon The conventional name for a background, non-interactive process.
data directory The le-system location where the mongod (page 555) stores data les. The dbPath option speci-
es the data directory.
data-center awareness A property that allows clients to address members in a system based on their locations.
Replica sets implement data-center awareness using tagging. See /data-center-awareness.
database A physical container for collections. Each database gets its own set of les on the le system. A single
MongoDB server typically has multiple databases.
database command A MongoDB operation, other than an insert, update, remove, or query. For a list of database
commands, see Database Commands (page 208). To use database commands, see issue-commands.
database proler A tool that, when enabled, keeps a record on all long-running operations in a databases
system.profile collection. The proler is most often used to diagnose slow queries. See database-
proling.
datum A set of values used to dene measurements on the earth. Mon-
goDB uses the WGS84 datum in certain geospatial calculations. See
http://docs.mongodb.org/manualapplications/geospatial-indexes.
dbpath The location of MongoDBs data le storage. See dbPath.
delayed member A replica set member that cannot become primary and applies operations at a specied delay. The
delay is useful for protecting data from human error (i.e. unintentionally deleted databases) or updates that have
unforeseen effects on the production database. See replica-set-delayed-members.
diagnostic log A verbose log of operations stored in the dbpath. See the --diaglog option.
6.3. Glossary 665
MongoDB Reference Manual, Release 2.6.4
document A record in a MongoDB collection and the basic unit of data in MongoDB. Documents are anal-
ogous to JSON objects but exist in the database in a more type-rich format known as BSON. See
http://docs.mongodb.org/manualcore/document.
dot notation MongoDB uses the dot notation to access the elements of an array and to access the elds of a subdoc-
ument. See document-dot-notation.
draining The process of removing or shedding chunks from one shard to another.
Administrators must drain shards before removing them from the cluster. See
http://docs.mongodb.org/manualtutorial/remove-shards-from-cluster.
driver A client library for interacting with MongoDB in a particular language. See
http://docs.mongodb.org/manualapplications/drivers.
election The process by which members of a replica set select a primary on startup and in the event of a failure. See
replica-set-elections.
eventual consistency A property of a distributed system that allows changes to the system to propagate gradually. In
a database system, this means that readable members are not required to reect the latest writes at all times. In
MongoDB, reads to a primary have strict consistency; reads to secondaries have eventual consistency.
expression In the context of aggregation framework, expressions are the stateless transformations that operate on the
data that passes through a pipeline. See http://docs.mongodb.org/manualcore/aggregation.
failover The process that allows a secondary member of a replica set to become primary in the event of a failure.
See replica-set-failover.
eld A name-value pair in a document. A document has zero or more elds. Fields are analogous to columns in
relational databases. See document-structure.
eld path Path to a eld in the document. To specify a eld path, use a string that prexes the eld name with a
dollar sign ($).
rewall A system level networking lter that restricts access based on, among other things, IP address. Firewalls
form a part of an effective network security strategy. See security-rewalls.
fsync A system call that ushes all dirty, in-memory pages to disk. MongoDB calls fsync() on its database les
at least every 60 seconds. See fsync (page 328).
geohash A geohash value is a binary representation of the location on a coordinate grid. See geospatial-indexes-
geohash.
GeoJSON A geospatial data interchange format based on JavaScript Object Notation (JSON). GeoJSON is used in
geospatial queries. For supported GeoJSON objects, see geo-overview-location-data. For the GeoJ-
SON format specication, see http://geojson.org/geojson-spec.html.
geospatial Data that relates to geographical location. In MongoDB, you may
store, index, and query data according to geographical parameters. See
http://docs.mongodb.org/manualapplications/geospatial-indexes.
GridFS A convention for storing large les in a MongoDB database. All of the
ofcial MongoDB drivers support this convention, as does the mongofiles
(page 639) program. See http://docs.mongodb.org/manualcore/gridfs and
http://docs.mongodb.org/manualreference/gridfs.
hashed shard key A special type of shard key that uses a hash of the value in the shard key eld to distribute
documents among members of the sharded cluster. See index-type-hashed.
haystack index A geospatial index that enhances searches by creating buckets of objects grouped by a second
criterion. See http://docs.mongodb.org/manualcore/geohaystack.
hidden member A replica set member that cannot become primary and are invisible to client applications. See
replica-set-hidden-members.
666 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
idempotent The quality of an operation to produce the same result given the same input, whether run once or run
multiple times.
index A data structure that optimizes queries. See http://docs.mongodb.org/manualcore/indexes.
initial sync The replica set operation that replicates data from an existing replica set member to a new or restored
replica set member. See replica-set-initial-sync.
interrupt point A point in an operations lifecycle when it can safely abort. Mon-
goDB only terminates an operation at designated interrupt points. See
http://docs.mongodb.org/manualtutorial/terminate-running-operations.
IPv6 A revision to the IP (Internet Protocol) standard that provides a signicantly larger address space to more
effectively support the number of hosts on the contemporary Internet.
ISODate The international date format used by mongo (page 580) to display dates. The format is: YYYY-MM-DD
HH:MM.SS.millis.
JavaScript A popular scripting language originally designed for web browsers. The
MongoDB shell and certain server-side functions use a JavaScript interpreter. See
http://docs.mongodb.org/manualcore/server-side-javascript for more information.
journal A sequential, binary transaction log used to bring the database into a valid state in the event of a hard
shutdown. Journaling writes data rst to the journal and then to the core data les. MongoDB enables journaling
by default for 64-bit builds of MongoDB version 2.0 and newer. Journal les are pre-allocated and exist as les
in the data directory. See http://docs.mongodb.org/manualcore/journaling/.
JSON JavaScript Object Notation. A human-readable, plain text format for expressing structured data
with support in many programming languages. For more information, see http://www.json.org. Cer-
tain MongoDB tools render an approximation of MongoDB BSON documents in JSON format. See
http://docs.mongodb.org/manualreference/mongodb-extended-json.
JSON document A JSON document is a collection of elds and values in a structured format. For sample JSON
documents, see http://json.org/example.html.
JSONP JSON with Padding. Refers to a method of injecting JSON into applications. Presents potential security
concerns.
least privilege An authorization policy that gives a user only the amount of access that is essential to that users work
and no more.
legacy coordinate pairs The format used for geospatial data prior to MongoDB version 2.4. This for-
mat stores geospatial data as points on a planar coordinate system (e.g. [ x, y ]). See
http://docs.mongodb.org/manualapplications/geospatial-indexes.
LineString A LineString is dened by an array of two or more positions. A closed LineString with four or more posi-
tions is called a LinearRing, as described in the GeoJSON LineString specication: http://geojson.org/geojson-
spec.html#linestring. To use a LineString in MongoDB, see geospatial-indexes-store-geojson.
lock MongoDB uses locks to ensure concurrency. MongoDB uses both read locks and write locks. For more
information, see faq-concurrency-locking.
LVM Logical volume manager. LVM is a program that abstracts disk images from physical devices and provides a
number of raw disk manipulation and snapshot capabilities useful for system management. For information on
LVM and MongoDB, see lvm-backup-and-restore.
map-reduce Adata processing and aggregation paradigmconsisting of a map phase that selects data and a reduce
phase that transforms the data. In MongoDB, you can run arbitrary aggregations over data using map-reduce.
For map-reduce implementation, see http://docs.mongodb.org/manualcore/map-reduce. For
all approaches to aggregation, see http://docs.mongodb.org/manualcore/aggregation.
6.3. Glossary 667
MongoDB Reference Manual, Release 2.6.4
mapping type A Structure in programming languages that associate keys with values, where keys may nest other
pairs of keys and values (e.g. dictionaries, hashes, maps, and associative arrays). The properties of these
structures depend on the language specication and implementation. Generally the order of keys in mapping
types is arbitrary and not guaranteed.
master The database that receives all writes in a conventional master-slave replication. In MongoDB, replica sets
replace master-slave replication for most use cases. For more information on master-slave replication, see
http://docs.mongodb.org/manualcore/master-slave.
md5 A hashing algorithm used to efciently provide reproducible unique strings to identify and checksum data.
MongoDB uses md5 to identify chunks of data for GridFS. See lemd5 (page 328).
MIB Management Information Base. MongoDB uses MIB les to dene the type of data tracked by SNMP in the
MongoDB Enterprise edition.
MIME Multipurpose Internet Mail Extensions. A standard set of type and encoding denitions used to declare
the encoding and type of data in multiple data storage, transmission, and email contexts. The mongofiles
(page 639) tool provides an option to specify a MIME type to describe a le inserted into GridFS storage.
mongo The MongoDB shell. The mongo (page 580) process starts the MongoDB shell as a daemon connected to
either a mongod (page 555) or mongos (page 571) instance. The shell has a JavaScript interface. See mongo
(page 580) and mongo Shell Methods (page 21).
mongod The MongoDB database server. The mongod (page 555) process starts the MongoDB server as a daemon.
The MongoDB server manages data requests and formats and manages background operations. See mongod
(page 555).
MongoDB An open-source document-based database system. MongoDB derives from the word humongous
because of the databases ability to scale up with ease and hold very large amounts of data. MongoDB stores
documents in collections within databases.
MongoDB Enterprise A commercial edition of MongoDB that includes additional features. For more information,
see MongoDB Subscriptions
1
.
mongos The routing and load balancing process that acts an interface between an application and a MongoDB
sharded cluster. See mongos (page 570).
namespace The canonical name for a collection or index in MongoDB. The namespace is
a combination of the database name and the name of the collection or index, like so:
[database-name].[collection-or-index-name]. All documents belong to a namespace.
See faq-dev-namespace.
natural order The order that a database stores documents on disk. Typically, the order of documents on disks reects
insertion order, except when a document moves internally because an update operation increases its size. In
capped collections, insertion order and natural order are identical because documents do not move internally.
MongoDB returns documents in forward natural order for a find() (page 33) query with no parameters.
MongoDB returns documents in reverse natural order for a find() (page 33) query sorted (page 96) with a
parameter of $natural:-1. See $natural (page 535).
ObjectId A special 12-byte BSON type that guarantees uniqueness within the collection. The ObjectId is generated
based on timestamp, machine ID, process ID, and a process-local incremental counter. MongoDB uses ObjectId
values as the default values for _id elds.
operator A keyword beginning with a $ used to express an update, complex query, or data transformation. For
example, $gt is the query languages greater than operator. For available operators, see Operators (page 386).
oplog A capped collection that stores an ordered history of logical writes to a MongoDB
database. The oplog is the basic mechanism enabling replication in MongoDB. See
http://docs.mongodb.org/manualcore/replica-set-oplog.
1
https://www.mongodb.com/products/mongodb-subscriptions
668 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
ordered query plan A query plan that returns results in the order consistent with the sort() (page 96) order. See
read-operations-query-optimization.
orphaned document In a sharded cluster, orphaned documents are those documents on a shard that also exist in
chunks on other shards as a result of failed migrations or incomplete migration cleanup due to abnormal shut-
down. Delete orphaned documents using cleanupOrphaned (page 298) to reclaim disk space and reduce
confusion.
padding The extra space allocated to document on the disk to prevent moving a document when it grows as the result
of update() (page 70) operations. See record-allocation-strategies.
padding factor An automatically-calibrated constant used to determine how much extra space MongoDB should
allocate per document container on disk. A padding factor of 1 means that MongoDB will allocate only the
amount of space needed for the document. A padding factor of 2 means that MongoDB will allocate twice the
amount of space required by the document. See record-allocation-strategies.
page fault Page faults can occur as MongoDB reads from or writes data to parts of its data les that are not cur-
rently located in physical memory. In contrast, operating system page faults happen when physical memory is
exhausted and pages of physical memory are swapped to disk.
See administration-monitoring-page-faults and faq-storage-page-faults.
partition A distributed system architecture that splits data into ranges. Sharding uses partitioning. See sharding-
data-partitioning.
passive member A member of a replica set that cannot become primary because its priority is 0. See
http://docs.mongodb.org/manualcore/replica-set-priority-0-member.
pcap A packet-capture format used by mongosniff (page 635) to record packets captured from network interfaces
and display them as human-readable MongoDB operations. See Options (page 635).
PID A process identier. UNIX-like systems assign a unique-integer PID to each running process. You can use a
PID to inspect a running process and send signals to it. See proc-le-system.
pipe A communication channel in UNIX-like systems allowing independent processes to send and receive data. In
the UNIX shell, piped operations allow users to direct the output of one command into the input of another.
pipeline Aseries of operations in an aggregation process. See http://docs.mongodb.org/manualcore/aggregation.
Point A single coordinate pair as described in the GeoJSON Point specication: http://geojson.org/geojson-
spec.html#point. To use a Point in MongoDB, see geospatial-indexes-store-geojson.
Polygon An array of LinearRing coordinate arrays, as described in the GeoJSON Polygon specication:
http://geojson.org/geojson-spec.html#polygon. For Polygons with multiple rings, the rst must be the exterior
ring and any others must be interior rings or holes.
MongoDB does not permit the exterior ring to self-intersect. Interior rings must be fully contained within the
outer loop and cannot intersect or overlap with each other. See geospatial-indexes-store-geojson.
powerOf2Sizes A per-collection setting that changes and normalizes the way MongoDB allocates space for each
document, in an effort to maximize storage reuse and to reduce fragmentation. This is the default for TTL
Collections. See collMod (page 314) and usePowerOf2Sizes (page 314).
pre-splitting An operation performed before inserting data that divides the range of possible
shard key values into chunks to facilitate easy insertion and high write throughput. In some
cases pre-splitting expedites the initial distribution of documents in sharded cluster by man-
ually dividing the collection rather than waiting for the MongoDB balancer to do so. See
http://docs.mongodb.org/manualtutorial/create-chunks-in-sharded-cluster.
primary In a replica set, the primary member is the current master instance, which receives all write operations. See
replica-set-primary-member.
6.3. Glossary 669
MongoDB Reference Manual, Release 2.6.4
primary key A records unique immutable identier. In an RDBMS, the primary key is typically an integer stored
in each rows id eld. In MongoDB, the _id eld holds a documents primary key which is usually a BSON
ObjectId.
primary shard The shard that holds all the un-sharded collections. See primary-shard.
priority A congurable value that helps determine which members in a replica set are most likely to become primary.
See priority.
privilege A combination of specied resource and actions permitted on the resource. See privilege.
projection A document given to a query that species which elds MongoDB returns in the result set. See projection.
For a list of projection operators, see Projection Operators (page 422).
query A read request. MongoDB uses a JSON-like query language that includes a variety of query operators with
names that begin with a $ character. In the mongo (page 580) shell, you can issue queries using the find()
(page 33) and findOne() (page 42) methods. See read-operations-queries.
query optimizer A process that generates query plans. For each query, the optimizer generates a plan that matches
the query to the index that will return results as efciently as possible. The optimizer reuses the query plan
each time the query runs. If a collection changes signicantly, the optimizer creates a new query plan. See
read-operations-query-optimization.
query shape A combination of query predicate, sort, and projection specications.
For the query predicate, only the structure of the predicate, including the eld names, are signicant; the values
in the query predicate are insignicant. As such, a query predicate { type: food } is equivalent to the
query predicate { type: utensil } for a query shape.
RDBMS Relational Database Management System. A database management system based on the relational model,
typically using SQL as the query language.
read lock In the context of a reader-writer lock, a lock that while held allows concurrent readers but no writers. See
faq-concurrency-locking.
read preference A setting that determines how clients direct read operations. Read preference affects all replica sets,
including shards. By default, MongoDB directs reads to primaries for strict consistency. However, you may
also direct reads to secondaries for eventually consistent reads. See Read Preference.
record size The space allocated for a document including the padding. For more information on padding, see record-
allocation-strategies and compact (page 315).
recovering Areplica set member status indicating that a member is not ready to begin normal activities of a secondary
or primary. Recovering members are unavailable for reads.
replica pairs The precursor to the MongoDB replica sets.
Deprecated since version 1.6.
replica set A cluster of MongoDB servers that implements master-slave replication and automated failover. Mon-
goDBs recommended replication strategy. See http://docs.mongodb.org/manualreplication.
replication A feature allowing multiple database servers to share the same data, thereby ensuring redundancy and
facilitating load balancing. See http://docs.mongodb.org/manualreplication.
replication lag The length of time between the last operation in the primarys oplog and the last operation applied to
a particular secondary. In general, you want to keep replication lag as small as possible. See Replication Lag.
resident memory The subset of an applications memory currently stored in physical RAM. Resident memory is a
subset of virtual memory, which includes memory mapped to physical RAM and to disk.
resource A database, collection, set of collections, or cluster. A privilege permits actions on a specied resource.
See resource.
670 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
REST An API design pattern centered around the idea of resources and the CRUD operations that apply to them.
Typically REST is implemented over HTTP. MongoDB provides a simple HTTP REST interface that allows
HTTP clients to run commands against the server. See rest-interface and rest-api.
role A set of privileges that permit actions on specied resources. Roles as-
signed to a user determine the users access to resources and operations. See
http://docs.mongodb.org/manualcore/security-introduction.
rollback A process that reverts writes operations to ensure the consistency of all replica set members. See replica-
set-rollback.
secondary A replica set member that replicates the contents of the master database. Secondary members may handle
read requests, but only the primary members can handle write operations. See replica-set-secondary-members.
secondary index A database index that improves query performance by minimizing the amount of work that the
query engine must perform to fulll a query. See http://docs.mongodb.org/manualindexes.
set name The arbitrary name given to a replica set. All members of a replica set must have the same name specied
with the replSetName setting or the --replSet option.
shard A single mongod (page 555) instance or replica set that stores some portion of a
sharded clusters total data set. In production, all shards should be replica sets. See
http://docs.mongodb.org/manualcore/sharded-cluster-shards.
shard key The eld MongoDB uses to distribute documents among members of a sharded cluster. See shard-key.
sharded cluster The set of nodes comprising a sharded MongoDB deployment. A sharded cluster consists of
three cong processes, one or more replica sets, and one or more mongos (page 571) routing processes. See
http://docs.mongodb.org/manualcore/sharded-cluster-components.
sharding A database architecture that partitions data by key ranges and distributes the data
among two or more database instances. Sharding enables horizontal scaling. See
http://docs.mongodb.org/manualsharding.
shell helper A method in the mongo shell that provides a more concise syntax for a database command (page 208).
Shell helpers improve the general interactive experience. See mongo Shell Methods (page 21).
single-master replication A replication topology where only a single database instance accepts writes. Single-
master replication ensures consistency and is the replication topology employed by MongoDB. See
http://docs.mongodb.org/manualcore/replica-set-primary.
slave A read-only database that replicates operations from a master database in conventional master/slave replication.
In MongoDB, replica sets replace master/slave replication for most use cases. However, for information on
master/slave replication, see http://docs.mongodb.org/manualcore/master-slave.
split The division between chunks in a sharded cluster. See http://docs.mongodb.org/manualcore/sharding-chunk-splitting.
SQL Structured Query Language (SQL) is a common special-purpose programming language used for interaction
with a relational database, including access control, insertions, updates, queries, and deletions. There are some
similar elements in the basic SQL syntax supported by different database vendors, but most implementations
have their own dialects, data types, and interpretations of proposed SQL standards. Complex SQL is generally
not directly portable between major RDBMS products. SQL is often used as metonym for relational databases.
SSD Solid State Disk. A high-performance disk drive that uses solid state electronics for persistence, as opposed to
the rotating platters and movable read/write heads used by traditional mechanical hard drives.
stale Refers to the amount of time a secondary member of a replica set trails behind the current state of the
primarysoplog. If a secondary becomes too stale, it can no longer use replication to catch up to the cur-
rent state of the primary. See http://docs.mongodb.org/manualcore/replica-set-oplog and
http://docs.mongodb.org/manualcore/replica-set-sync for more information.
6.3. Glossary 671
MongoDB Reference Manual, Release 2.6.4
standalone An instance of mongod (page 555) that is running as a single server and
not as part of a replica set. To convert a standalone into a replica set, see
http://docs.mongodb.org/manualtutorial/convert-standalone-to-replica-set.
strict consistency A property of a distributed system requiring that all members always reect the latest changes to
the system. In a database system, this means that any system that can provide data must reect the latest writes
at all times. In MongoDB, reads from a primary have strict consistency; reads from secondary members have
eventual consistency.
sync The replica set operation where members replicate data from the primary. Sync rst oc-
curs when MongoDB creates or restores a member, which is called initial sync. Sync then
occurs continually to keep the member updated with changes to the replica sets data. See
http://docs.mongodb.org/manualcore/replica-set-sync.
syslog On UNIX-like systems, a logging process that provides a uniform standard for servers and processes to
submit logging information. MongoDB provides an option to send output to the hosts syslog system. See
syslogFacility.
tag A label applied to a replica set member or shard and used by clients to issue data-center-aware operations. For
more information on using tags with replica sets and with shards, see the following sections of this manual:
replica-set-read-preference-tag-sets and shards-tag-sets.
tailable cursor For a capped collection, a tailable cursor is a cursor that remains open af-
ter the client exhausts the results in the initial cursor. As clients insert new docu-
ments into the capped collection, the tailable cursor continues to retrieve documents. See
http://docs.mongodb.org/manualtutorial/create-tailable-cursor.
TSV A text-based data format consisting of tab-separated values. This format is commonly used to exchange data
between relational databases, since the format is well-suited to tabular data. You can import TSV les using
mongoimport (page 610).
TTL Stands for time to live and represents an expiration time or period for a given piece of information to remain
in a cache or other temporary storage before the system deletes it or ages it out. MongoDB has a TTL collection
feature. See http://docs.mongodb.org/manualtutorial/expire-data.
unique index An index that enforces uniqueness for a particular eld across a single collection. See index-type-
unique.
unix epoch January 1st, 1970 at 00:00:00 UTC. Commonly used in expressing time, where the number of seconds
or milliseconds since this point is counted.
unordered query plan A query plan that returns results in an order inconsistent with the sort() (page 96) order.
See read-operations-query-optimization.
upsert An option for update operations. If set to true, the update operation will either update the rst document
matched by a query or insert a new document if none matches. The new document will have the elds implied
by the operation. The update() (page 70) and findAndModify() (page 38) have the option. See Upsert
Option (page 72).
virtual memory An applications working memory, typically residing on both disk an in physical RAM.
WGS84 The default datum MongoDB uses to calculate geometry over an Earth-like sphere. MongoDB uses the
WGS84 datum for geospatial queries on GeoJSON objects. See the EPSG:4326: WGS 84 specication:
http://spatialreference.org/ref/epsg/4326/.
working set The data that MongoDB uses most often. This data is preferably held in RAM, solid-state drive (SSD),
or other fast media. See faq-working-set.
write concern Species whether a write operation has succeeded. Write concern allows your appli-
cation to detect insertion errors or unavailable mongod (page 555) instances. For replica sets,
672 Chapter 6. General System Reference
MongoDB Reference Manual, Release 2.6.4
you can congure write concern to conrm replication to a specied number of members. See
http://docs.mongodb.org/manualcore/write-concern.
write lock A lock on the database for a given writer. When a process writes to the database, it takes an ex-
clusive write lock to prevent other processes from writing or reading. For more information on locks, see
http://docs.mongodb.org/manualfaq/concurrency.
writeBacks The process within the sharding system that ensures that writes issued to a shard that is not responsible
for the relevant chunk get applied to the proper shard. For related information, see faq-writebacklisten and
writeBacksQueued (page 364).
6.3. Glossary 673
MongoDB Reference Manual, Release 2.6.4
674 Chapter 6. General System Reference
CHAPTER 7
Release Notes
Always install the latest, stable version of MongoDB. See release-version-numbers for more information.
See the following release notes for an account of the changes in major versions. Release notes also include instructions
for upgrade.
7.1 Current Stable Release
(2.6-series)
7.1.1 Release Notes for MongoDB 2.6
April 8, 2014
MongoDB 2.6 is now available. Key features include aggregation enhancements, text-search integration, query-engine
improvements, a new write-operation protocol, and security enhancements.
MMS 1.4, which includes On-Prem Backup in addition to Monitoring, is now also available. See MMS 1.4 documen-
tation
1
and the MMS 1.4 release notes
2
for more information.
Minor Releases
2.6 Changelog
2.6.4 Changes
Security
SERVER-14701
3
The backup auth role should allow running the collstats command for all resources
SERVER-14518
4
Allow disabling hostname validation for SSL
SERVER-14268
5
Potential information leak
1
https://mms.mongodb.com/help-hosted/v1.4/
2
https://mms.mongodb.com/help-hosted/v1.4/management/changelog/
3
https://jira.mongodb.org/browse/SERVER-14701
4
https://jira.mongodb.org/browse/SERVER-14518
5
https://jira.mongodb.org/browse/SERVER-14268
675
MongoDB Reference Manual, Release 2.6.4
SERVER-14170
6
Cannot read from secondary if both audit and auth are enabled in a sharded cluster
SERVER-13833
7
userAdminAnyDatabase role should be able to create indexes on admin.system.users and
admin.system.roles
SERVER-12512
8
Add role-based, selective audit logging.
SERVER-9482
9
Add build ag for sslFIPSMode
Querying
SERVER-14625
10
Query planner can construct incorrect bounds for negations inside $elemMatch
SERVER-14607
11
hash intersection of fetched and non-fetched data can discard data from a result
SERVER-14532
12
Improve logging in the case of plan ranker ties
SERVER-14350
13
Server crash when $centerSphere has non-positive radius
SERVER-14317
14
Dead code in IDHackRunner::applyProjection
SERVER-14311
15
skipping of index keys is not accounted for in plan ranking by the index scan stage
SERVER-14123
16
some operations can create BSON object larger than the 16MB limit
SERVER-14034
17
Sorted $in query with large number of elements cant use merge sort
SERVER-13994
18
do not aggressively pre-fetch data for parallelCollectionScan
Replication
SERVER-14665
19
Build failure for v2.6 in closeall.js caused by access violation reading _me
SERVER-14505
20
cannot dropAllIndexes when index builds in progress assertion failure
SERVER-14494
21
Dropping collection during active background index build on secondary triggers segfault
SERVER-13822
22
Running resync before replset cong is loaded can crash mongod (page 555)
SERVER-11776
23
Replication isself check should allow mapped ports
Sharding
SERVER-14551
24
Runner yield during migration cleanup (removeRange) results in fassert
6
https://jira.mongodb.org/browse/SERVER-14170
7
https://jira.mongodb.org/browse/SERVER-13833
8
https://jira.mongodb.org/browse/SERVER-12512
9
https://jira.mongodb.org/browse/SERVER-9482
10
https://jira.mongodb.org/browse/SERVER-14625
11
https://jira.mongodb.org/browse/SERVER-14607
12
https://jira.mongodb.org/browse/SERVER-14532
13
https://jira.mongodb.org/browse/SERVER-14350
14
https://jira.mongodb.org/browse/SERVER-14317
15
https://jira.mongodb.org/browse/SERVER-14311
16
https://jira.mongodb.org/browse/SERVER-14123
17
https://jira.mongodb.org/browse/SERVER-14034
18
https://jira.mongodb.org/browse/SERVER-13994
19
https://jira.mongodb.org/browse/SERVER-14665
20
https://jira.mongodb.org/browse/SERVER-14505
21
https://jira.mongodb.org/browse/SERVER-14494
22
https://jira.mongodb.org/browse/SERVER-13822
23
https://jira.mongodb.org/browse/SERVER-11776
24
https://jira.mongodb.org/browse/SERVER-14551
676 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
SERVER-14431
25
Invalid chunk data after splitting on a key thats too large
SERVER-14261
26
stepdown during migration range delete can abort mongod (page 555)
SERVER-14032
27
v2.6 mongos (page 571) doesnt verify _id is present for cong server upserts
SERVER-13648
28
better stats from migration cleanup
SERVER-12750
29
mongos (page 571) shouldnt accept initial query with exhaust ag set
SERVER-9788
30
mongos (page 571) does not re-evaluate read preference once a valid replica set member is
chosen
SERVER-9526
31
Log messages regarding chunks not very informative when the shard key is of type BinData
Storage
SERVER-14198
32
Std::set<pointer> and Windows Heap Allocation Reuse produces non-deterministic results
SERVER-13975
33
Creating index on collection named system can cause server to abort
SERVER-13729
34
Reads & Writes are blocked during data le allocation on Windows
SERVER-13681
35
mongod (page 555) B stalls during background ush on Windows
Indexing SERVER-14494
36
Dropping collection during active background index build on secondary triggers seg-
fault
Write Ops
SERVER-14257
37
remove command can cause process termination by throwing unhandled exception if pro-
ling is enabled
SERVER-14024
38
Update fails when query contains part of a DBRef and results in an insert (upsert:true)
SERVER-13764
39
debug mechanisms report incorrect nscanned / nscannedObjects for updates
Networking SERVER-13734
40
Remove catch (...) from handleIncomingMsg
Geo
SERVER-14039
41
$nearSphere query with 2d index, skip, and limit returns incomplete results
25
https://jira.mongodb.org/browse/SERVER-14431
26
https://jira.mongodb.org/browse/SERVER-14261
27
https://jira.mongodb.org/browse/SERVER-14032
28
https://jira.mongodb.org/browse/SERVER-13648
29
https://jira.mongodb.org/browse/SERVER-12750
30
https://jira.mongodb.org/browse/SERVER-9788
31
https://jira.mongodb.org/browse/SERVER-9526
32
https://jira.mongodb.org/browse/SERVER-14198
33
https://jira.mongodb.org/browse/SERVER-13975
34
https://jira.mongodb.org/browse/SERVER-13729
35
https://jira.mongodb.org/browse/SERVER-13681
36
https://jira.mongodb.org/browse/SERVER-14494
37
https://jira.mongodb.org/browse/SERVER-14257
38
https://jira.mongodb.org/browse/SERVER-14024
39
https://jira.mongodb.org/browse/SERVER-13764
40
https://jira.mongodb.org/browse/SERVER-13734
41
https://jira.mongodb.org/browse/SERVER-14039
7.1. Current Stable Release 677
MongoDB Reference Manual, Release 2.6.4
SERVER-13701
42
Query using 2d index throws exception when using explain()
Text Search
SERVER-14738
43
Updates to documents with text-indexed elds may lead to incorrect entries
SERVER-14027
44
Renaming collection within same database fails if wildcard text index present
Tools
SERVER-14212
45
mongorestore (page 597) may drop system users and roles
SERVER-14048
46
mongodump (page 590) against mongos (page 571) cant send dump to standard output
Admin
SERVER-14556
47
Default dbpath for mongod (page 555) --configsvr (page 565) changes in 2.6
SERVER-14355
48
Allow dbAdmin role to manually create system.prole collections
Packaging SERVER-14283
49
Parameters in installed cong le are out of date
JavaScript
SERVER-14254
50
Do not store native function pointer as a property in function prototype
SERVER-13798
51
v8 garbage collection can cause crash due to independent lifetime of DBClient and Cursor
objects
SERVER-13707
52
mongo shell may crash when converting invalid regular expression
Shell
SERVER-14341
53
negative opcounter values in serverStatus
SERVER-14107
54
Querying for a document containing a value of either type Javascript or JavascriptWithScope
crashes the shell
Usability SERVER-13833
55
userAdminAnyDatabase role should be able to create indexes on admin.system.users
and admin.system.roles
42
https://jira.mongodb.org/browse/SERVER-13701
43
https://jira.mongodb.org/browse/SERVER-14738
44
https://jira.mongodb.org/browse/SERVER-14027
45
https://jira.mongodb.org/browse/SERVER-14212
46
https://jira.mongodb.org/browse/SERVER-14048
47
https://jira.mongodb.org/browse/SERVER-14556
48
https://jira.mongodb.org/browse/SERVER-14355
49
https://jira.mongodb.org/browse/SERVER-14283
50
https://jira.mongodb.org/browse/SERVER-14254
51
https://jira.mongodb.org/browse/SERVER-13798
52
https://jira.mongodb.org/browse/SERVER-13707
53
https://jira.mongodb.org/browse/SERVER-14341
54
https://jira.mongodb.org/browse/SERVER-14107
55
https://jira.mongodb.org/browse/SERVER-13833
678 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Logging and Diagnostics
SERVER-12512
56
Add role-based, selective audit logging.
SERVER-14341
57
negative opcounter values in serverStatus
Testing
SERVER-14731
58
plan_cache_ties.js sometimes fails
SERVER-14147
59
make index_multi.js retry on connection failure
SERVER-13615
60
sharding_rs2.js intermittent failure due to reliance on opcounters
2.6.3 Changes
SERVER-14302
61
Fixed: Equality queries on _id with projection may return no results on sharded collec-
tions
SERVER-14304
62
Fixed: Equality queries on _id with projection on _id may return orphan documents on
sharded collections
2.6.2 Changes
Security
SERVER-13727
63
The backup authorization role now includes privileges to run the collStats (page 338)
command.
SERVER-13804
64
The built-in role restore now has privileges on system.roles collection.
SERVER-13612
65
Fixed: SSL-enabled server appears not to be sending the list of supported certicate issuers
to the client
SERVER-13753
66
Fixed: mongod (page 555) may terminate if x.509 authentication certicate is invalid
SERVER-13945
67
For replica set/sharded cluster member authentication, nowmatches x.509 cluster certicates
by attributes instead of by substring comparison.
SERVER-13868
68
Now marks V1 users as probed on databases that do not have surrogate user documents.
SERVER-13850
69
Now ensures that the user cache entry is up to date before using it to determine a users roles
in user management commands on mongos (page 571).
SERVER-13588
70
Fixed: Shell prints startup warning when auth enabled
56
https://jira.mongodb.org/browse/SERVER-12512
57
https://jira.mongodb.org/browse/SERVER-14341
58
https://jira.mongodb.org/browse/SERVER-14731
59
https://jira.mongodb.org/browse/SERVER-14147
60
https://jira.mongodb.org/browse/SERVER-13615
61
https://jira.mongodb.org/browse/SERVER-14302
62
https://jira.mongodb.org/browse/SERVER-14304
63
https://jira.mongodb.org/browse/SERVER-13727
64
https://jira.mongodb.org/browse/SERVER-13804
65
https://jira.mongodb.org/browse/SERVER-13612
66
https://jira.mongodb.org/browse/SERVER-13753
67
https://jira.mongodb.org/browse/SERVER-13945
68
https://jira.mongodb.org/browse/SERVER-13868
69
https://jira.mongodb.org/browse/SERVER-13850
70
https://jira.mongodb.org/browse/SERVER-13588
7.1. Current Stable Release 679
MongoDB Reference Manual, Release 2.6.4
Querying
SERVER-13731
71
Fixed: Stack overow when parsing deeply nested $not (page 392) query
SERVER-13890
72
Fixed: Index bounds builder constructs invalid bounds for multiple negations joined by an
$or (page 393)
SERVER-13752
73
Veried assertion on empty $in (page 387) clause and sort on second eld in a compound
index.
SERVER-13337
74
Re-enabled idhack for queries with projection.
SERVER-13715
75
Fixed: Aggregation pipeline execution can fail with $or and blocking sorts
SERVER-13714
76
Fixed: non-top-level indexable $not (page 392) triggers query planning bug
SERVER-13769
77
Fixed: distinct (page 213) command on indexed eld with geo predicate fails to exe-
cute
SERVER-13675
78
Fixed Plans with differing performance can tie during plan ranking
SERVER-13899
79
Fixed: Whole index scan query solutions can use incompatible indexes, return incorrect
results
SERVER-13852
80
Fixed IndexBounds::endKeyInclusive not initialized by constructor
SERVER-14073
81
planSummary no longer truncated at 255 characters
SERVER-14174
82
Fixed: If ntoreturn is a limit (rather than batch size) extra data gets buffered during plan
ranking
SERVER-13789
83
Some nested queries no longer trigger an assertion error
SERVER-14064
84
Added planSummary information for count (page 211) command log message.
SERVER-13960
85
Queries containing $or (page 393) no longer miss results if multiple clauses use the same
index.
SERVER-14180
86
Fixed: Crash with and clause, $elemMatch (page 421), and nested $mod (page 398) or
regex
SERVER-14176
87
Natural order sort specication no longer ignored if query is specied.
SERVER-13754
88
Bounds no longer combined for $or (page 393) queries that can use merge sort.
71
https://jira.mongodb.org/browse/SERVER-13731
72
https://jira.mongodb.org/browse/SERVER-13890
73
https://jira.mongodb.org/browse/SERVER-13752
74
https://jira.mongodb.org/browse/SERVER-13337
75
https://jira.mongodb.org/browse/SERVER-13715
76
https://jira.mongodb.org/browse/SERVER-13714
77
https://jira.mongodb.org/browse/SERVER-13769
78
https://jira.mongodb.org/browse/SERVER-13675
79
https://jira.mongodb.org/browse/SERVER-13899
80
https://jira.mongodb.org/browse/SERVER-13852
81
https://jira.mongodb.org/browse/SERVER-14073
82
https://jira.mongodb.org/browse/SERVER-14174
83
https://jira.mongodb.org/browse/SERVER-13789
84
https://jira.mongodb.org/browse/SERVER-14064
85
https://jira.mongodb.org/browse/SERVER-13960
86
https://jira.mongodb.org/browse/SERVER-14180
87
https://jira.mongodb.org/browse/SERVER-14176
88
https://jira.mongodb.org/browse/SERVER-13754
680 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Geospatial SERVER-13687
89
Results of $near (page 410) query on compound multi-key 2dsphere index are now
sorted by distance.
Write Operations SERVER-13802
90
Insert eld validation no longer stops at rst Timestamp() eld.
Replication
SERVER-13993
91
Fixed: log a message when shouldChangeSyncTarget() believes a node should
change sync targets
SERVER-13976
92
Fixed: Cloner needs to detect failure to create collection
Sharding
SERVER-13616
93
Resolved: type 7 (OID) error when acquiring distributed lock for rst time
SERVER-13812
94
Now catches exception thrown by getShardsForQuery for geo query.
SERVER-14138
95
mongos (page 571) will now correctly target multiple shards for nested eld shard key
predicates.
SERVER-11332
96
Fixed: Authentication requests delayed if rst cong server is unresponsive
Map/Reduce
SERVER-14186
97
Resolved: rs.stepDown (page 177) during mapReduce causes fassert in logOp
SERVER-13981
98
Temporary map/reduce collections are now correctly replicated to secondaries.
Storage
SERVER-13750
99
convertToCapped (page 318) on empty collection no longer aborts after invariant()
failure.
SERVER-14056
100
Moving large collection across databases with renameCollection no longer triggers fatal
assertion.
SERVER-14082
101
Fixed: Excessive freelist scanning for MaxBucket
SERVER-13737
102
CollectionOptions parser now skips non-numeric for size/max elements if values non-
numeric.
89
https://jira.mongodb.org/browse/SERVER-13687
90
https://jira.mongodb.org/browse/SERVER-13802
91
https://jira.mongodb.org/browse/SERVER-13993
92
https://jira.mongodb.org/browse/SERVER-13976
93
https://jira.mongodb.org/browse/SERVER-13616
94
https://jira.mongodb.org/browse/SERVER-13812
95
https://jira.mongodb.org/browse/SERVER-14138
96
https://jira.mongodb.org/browse/SERVER-11332
97
https://jira.mongodb.org/browse/SERVER-14186
98
https://jira.mongodb.org/browse/SERVER-13981
99
https://jira.mongodb.org/browse/SERVER-13750
100
https://jira.mongodb.org/browse/SERVER-14056
101
https://jira.mongodb.org/browse/SERVER-14082
102
https://jira.mongodb.org/browse/SERVER-13737
7.1. Current Stable Release 681
MongoDB Reference Manual, Release 2.6.4
Build and Packaging
SERVER-13950
103
MongoDB Enterprise now includes required dependency list.
SERVER-13862
104
Support for mongodb-org-server installation 2.6.1-1 on RHEL5 via RPM.
SERVER-13724
105
Added SCons ag to override treating all warnings as errors.
Diagnostics
SERVER-13587
106
Resolved: ndeleted in system.profile documents reports 1 too few documents
removed
SERVER-13368
107
Improved exposure of timing information in currentOp.
Administration SERVER-13954
108
security.javascriptEnabled option is now available in the YAML
conguration le.
Tools
SERVER-10464
109
mongodump (page 590) can now query oplog.$main and oplog.rs when using
--dbpath.
SERVER-13760
110
mongoexport (page 616) can now handle large timestamps on Windows.
Shell
SERVER-13865
111
Shell now returns correct WriteResult for compatibility-mode upsert with non-OID
equality predicate on _id eld.
SERVER-13037
112
Fixed typo in error message for compatibility mode.
Internal Code
SERVER-13794
113
Fixed: Unused snapshot history consuming signicant heap space
SERVER-13446
114
Removed Solaris builds dependency on ILLUMOS libc.
SERVER-14092
115
MongoDB upgrade 2.4 to 2.6 check no longer returns an error in internal collections.
SERVER-14000
116
Added new lsb le location for Debian 7.1
Testing
SERVER-13723
117
Stabilized tags.js after a change in its timeout when it was ported to use write commands.
103
https://jira.mongodb.org/browse/SERVER-13950
104
https://jira.mongodb.org/browse/SERVER-13862
105
https://jira.mongodb.org/browse/SERVER-13724
106
https://jira.mongodb.org/browse/SERVER-13587
107
https://jira.mongodb.org/browse/SERVER-13368
108
https://jira.mongodb.org/browse/SERVER-13954
109
https://jira.mongodb.org/browse/SERVER-10464
110
https://jira.mongodb.org/browse/SERVER-13760
111
https://jira.mongodb.org/browse/SERVER-13865
112
https://jira.mongodb.org/browse/SERVER-13037
113
https://jira.mongodb.org/browse/SERVER-13794
114
https://jira.mongodb.org/browse/SERVER-13446
115
https://jira.mongodb.org/browse/SERVER-14092
116
https://jira.mongodb.org/browse/SERVER-14000
117
https://jira.mongodb.org/browse/SERVER-13723
682 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
SERVER-13494
118
Fixed: setup_multiversion_mongodb.py doesnt download 2.4.10 because of
non-numeric version sorting
SERVER-13603
119
Fixed: Test suites with options tests fail when run with --nopreallocj
SERVER-13948
120
Fixed: awaitReplication() failures related to getting a cong version from master
causing test failures
SERVER-13839
121
Fixed sync2.js failure.
SERVER-13972
122
Fixed connections_opened.js failure.
SERVER-13712
123
Reduced peak disk usage of test suites.
SERVER-14249
124
Added tests for querying oplog via mongodump (page 590) using --dbpath
SERVER-10462
125
Fixed: Windows le locking related buildbot failures
2.6.1 Changes
Stability SERVER-13739
126
Repair database failure can delete database les
Build and Packaging
SERVER-13287
127
Addition of debug symbols has doubled compile time
SERVER-13563
128
Upgrading from 2.4.x to 2.6.0 via yum clobbers conguration le
SERVER-13691
129
yum and apt stable repositories contain release candidate 2.6.1-rc0 packages
SERVER-13515
130
Cannot install MongoDB as a service on Windows
Querying
SERVER-13066
131
Negations over multikey elds do not use index
SERVER-13495
132
Concurrent GETMORE and KILLCURSORS operations can cause race condition and server
crash
SERVER-13503
133
The $where (page 404) operator should not be allowed under $elemMatch (page 421)
SERVER-13537
134
Large skip and and limit values can cause crash in blocking sort stage
SERVER-13557
135
Incorrect negation of $elemMatch value in 2.6
118
https://jira.mongodb.org/browse/SERVER-13494
119
https://jira.mongodb.org/browse/SERVER-13603
120
https://jira.mongodb.org/browse/SERVER-13948
121
https://jira.mongodb.org/browse/SERVER-13839
122
https://jira.mongodb.org/browse/SERVER-13972
123
https://jira.mongodb.org/browse/SERVER-13712
124
https://jira.mongodb.org/browse/SERVER-14249
125
https://jira.mongodb.org/browse/SERVER-10462
126
https://jira.mongodb.org/browse/SERVER-13739
127
https://jira.mongodb.org/browse/SERVER-13287
128
https://jira.mongodb.org/browse/SERVER-13563
129
https://jira.mongodb.org/browse/SERVER-13691
130
https://jira.mongodb.org/browse/SERVER-13515
131
https://jira.mongodb.org/browse/SERVER-13066
132
https://jira.mongodb.org/browse/SERVER-13495
133
https://jira.mongodb.org/browse/SERVER-13503
134
https://jira.mongodb.org/browse/SERVER-13537
135
https://jira.mongodb.org/browse/SERVER-13557
7.1. Current Stable Release 683
MongoDB Reference Manual, Release 2.6.4
SERVER-13562
136
Queries that use tailable cursors do not stream results if skip() is applied
SERVER-13566
137
Using the OplogReplay ag with extra predicates can yield incorrect results
SERVER-13611
138
Missing sort order for compound index leads to unnecessary in-memory sort
SERVER-13618
139
Optimization for sorted $in queries not applied to reverse sort order
SERVER-13661
140
Increase the maximum allowed depth of query objects
SERVER-13664
141
Query with $elemMatch (page 421) using a compound multikey index can generate in-
correct results
SERVER-13677
142
Query planner should traverse through $all while handling $elemMatch object predicates
SERVER-13766
143
Dropping index or collection while $or query is yielding triggers fatal assertion
Geospatial
SERVER-13666
144
$near (page 410) queries with out-of-bounds points in legacy format can lead to crashes
SERVER-13540
145
The geoNear (page 227) command no longer returns distance in radians for legacy point
SERVER-13486
146
: The geoNear (page 227) command can create too large BSON objects for aggregation.
Replication
SERVER-13500
147
Changing replica set conguration can crash running members
SERVER-13589
148
Background index builds from a 2.6.0 primary fail to complete on 2.4.x secondaries
SERVER-13620
149
Replicated data denition commands will fail on secondaries during background index build
SERVER-13496
150
Creating index with same name but different spec in mixed version replicaset can abort
replication
Sharding
SERVER-12638
151
Initial sharding with hashed shard key can result in duplicate split points
SERVER-13518
152
The _id eld is no longer automatically generated by mongos (page 571) when missing
SERVER-13777
153
Migrated ranges waiting for deletion do not report cursors still open
136
https://jira.mongodb.org/browse/SERVER-13562
137
https://jira.mongodb.org/browse/SERVER-13566
138
https://jira.mongodb.org/browse/SERVER-13611
139
https://jira.mongodb.org/browse/SERVER-13618
140
https://jira.mongodb.org/browse/SERVER-13661
141
https://jira.mongodb.org/browse/SERVER-13664
142
https://jira.mongodb.org/browse/SERVER-13677
143
https://jira.mongodb.org/browse/SERVER-13766
144
https://jira.mongodb.org/browse/SERVER-13666
145
https://jira.mongodb.org/browse/SERVER-13540
146
https://jira.mongodb.org/browse/SERVER-13486
147
https://jira.mongodb.org/browse/SERVER-13500
148
https://jira.mongodb.org/browse/SERVER-13589
149
https://jira.mongodb.org/browse/SERVER-13620
150
https://jira.mongodb.org/browse/SERVER-13496
151
https://jira.mongodb.org/browse/SERVER-12638
152
https://jira.mongodb.org/browse/SERVER-13518
153
https://jira.mongodb.org/browse/SERVER-13777
684 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Security
SERVER-9358
154
Log rotation can overwrite previous log les
SERVER-13644
155
Sensitive credentials in startup options are not redacted and may be exposed
SERVER-13441
156
Inconsistent error handling in user management shell helpers
Write Operations
SERVER-13466
157
Error message in collection creation failure contains incorrect namespace
SERVER-13499
158
Yield policy for batch-inserts should be the same as for batch-updates/deletes
SERVER-13516
159
Array updates on documents with more than 128 BSON elements may crash mongod
(page 555)
2.6.4 August 11, 2014
Fix for text index where under specic circumstances, in-place updates to a text-indexed eld may result in
incorrect/incomplete results SERVER-14738
160
Check the size of the split point before performing a manual split chunk operation SERVER-14431
161
Ensure read preferences are re-evaluated by drawing secondary connections from a global pool and releasing
back to the pool at the end of a query/command SERVER-9788
162
Allow read from secondaries when both audit and authorization are enabled in a sharded cluster SERVER-
14170
163
All issues closed in 2.6.4
164
2.6.3 June 19, 2014
Equality queries on _id with projection may return no results on sharded collections SERVER-14302
165
.
Equality queries on _id with projection on _id may return orphan documents on sharded collections SERVER-
14304
166
.
All issues closed in 2.6.3
167
.
154
https://jira.mongodb.org/browse/SERVER-9358
155
https://jira.mongodb.org/browse/SERVER-13644
156
https://jira.mongodb.org/browse/SERVER-13441
157
https://jira.mongodb.org/browse/SERVER-13466
158
https://jira.mongodb.org/browse/SERVER-13499
159
https://jira.mongodb.org/browse/SERVER-13516
160
https://jira.mongodb.org/browse/SERVER-14738
161
https://jira.mongodb.org/browse/SERVER-14431
162
https://jira.mongodb.org/browse/SERVER-9788
163
https://jira.mongodb.org/browse/SERVER-14170
164
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.6.4%22%20AND%20project%20%3D%20SERVER
165
https://jira.mongodb.org/browse/SERVER-14302
166
https://jira.mongodb.org/browse/SERVER-14304
167
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.6.3%22%20AND%20project%20%3D%20SERVER
7.1. Current Stable Release 685
MongoDB Reference Manual, Release 2.6.4
2.6.2 June 16, 2014
Query plans with differing performance can tie during plan ranking SERVER-13675
168
.
mongod (page 555) may terminate if x.509 authentication certicate is invalid SERVER-13753
169
.
Temporary map/reduce collections are incorrectly replicated to secondaries SERVER-13981
170
.
mongos (page 571) incorrectly targets multiple shards for nested eld shard key predicates SERVER-14138
171
.
rs.stepDown() (page 177) during mapReduce causes fassert when writing to op log SERVER-14186
172
.
All issues closed in 2.6.2
173
.
2.6.1 May 5, 2014
Fix to install MongoDB service on Windows with the --install option SERVER-13515
174
.
Allow direct upgrade from 2.4.x to 2.6.0 via yum SERVER-13563
175
.
Fix issues with background index builds on secondaries: SERVER-13589
176
and SERVER-13620
177
.
Redact credential information passed as startup options SERVER-13644
178
.
2.6.1 Changelog (page 683).
All issues closed in 2.6.1
179
.
Major Changes
The following changes in MongoDB affect both the standard and Enterprise editions:
Aggregation Enhancements
The aggregation pipeline adds the ability to return result sets of any size, either by returning a cursor or writing the
output to a collection. Additionally, the aggregation pipeline supports variables and adds new operations to handle sets
and redact data.
The db.collection.aggregate() (page 22) now returns a cursor, which enables the aggregation
pipeline to return result sets of any size.
Aggregation pipelines now support an explain operation to aid analysis of aggregation operations.
Aggregation can now use a more efcient external-disk-based sorting process.
New pipeline stages:
$out (page 465) stage to output to a collection.
168
https://jira.mongodb.org/browse/SERVER-13675
169
https://jira.mongodb.org/browse/SERVER-13753
170
https://jira.mongodb.org/browse/SERVER-13981
171
https://jira.mongodb.org/browse/SERVER-14138
172
https://jira.mongodb.org/browse/SERVER-14186
173
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.6.2%22%20AND%20project%20%3D%20SERVER
174
https://jira.mongodb.org/browse/SERVER-13515
175
https://jira.mongodb.org/browse/SERVER-13563
176
https://jira.mongodb.org/browse/SERVER-13589
177
https://jira.mongodb.org/browse/SERVER-13620
178
https://jira.mongodb.org/browse/SERVER-13644
179
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.6.1%22%20AND%20project%20%3D%20SERVER
686 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
$redact (page 469) stage to allow additional control to accessing the data.
New or modied operators:
set expression operators (page 480).
$let (page 505) and $map (page 506) operators to allow for the use of variables.
$literal (page 507) operator and $size (page 504) operator.
$cond (page 518) expression now accepts either an object or an array.
Text Search Integration
Text search is now enabled by default, and the query system, including the aggregation pipeline $match (page 464)
stage, includes the $text (page 401) operator, which resolves text-search queries.
MongoDB 2.6 includes an updated text index format and deprecates the text (page 248) command.
Insert and Update Improvements
Improvements to the update and insert systems include additional operations and improvements that increase consis-
tency of modied data.
MongoDB preserves the order of the document elds following write operations except for the following cases:
The _id eld is always the rst eld in the document.
Updates that include renaming (page 434) of eld names may result in the reordering of elds in the
document.
New or enhanced update operators:
$bit (page 454) operator supports bitwise xor operation.
$min (page 431) and $max (page 430) operators that performconditional update depending on the relative
size of the specied value and the current value of a eld.
$push (page 444) operator has enhanced support for the $sort (page 451), $slice (page 449), and
$each (page 446) modiers and supports a new $position (page 447) modier.
$currentDate (page 429) operator to set the value of a eld to the current date.
The $mul (page 432) operator for multiplicative increments for insert and update operations.
See also:
Update Operator Syntax Validation (page 697)
New Write Operation Protocol
A new write protocol integrates write operations with write concerns. The protocol also provides improved support
for bulk operations.
MongoDB 2.6 adds the write commands insert (page 245), update (page 249), and delete (page 232), which
provide the basis for the improved bulk insert. All ofcially supported MongoDB drivers support the new write
commands.
The mongo (page 580) shell now includes methods to perform bulk-write operations. See Bulk() (page 135) for
more information.
7.1. Current Stable Release 687
MongoDB Reference Manual, Release 2.6.4
See also:
Write Method Acknowledgements (page 693)
MSI Package for MongoDB Available for Windows
MongoDB now distributes MSI packages for Microsoft Windows. This is the recommended method for MongoDB
installation under Windows.
Security Improvements
MongoDB 2.6 enhances support for secure deployments through improved SSL support, x.509-based authentication,
an improved authorization system with more granular controls, as well as centralized credential storage, and improved
user management tools.
Specically these changes include:
A new authorization model that provides the ability to create custom user-dened-roles and the ability to specify
user privileges at a collection-level granularity.
Global user management, which stores all user and user-dened role data in the admin database and provides
a new set of commands for managing users and roles.
x.509 certicate authentication for client authentication as well as for internal
authentication of sharded and/or replica set cluster members. x.509 authentication is only avail-
able for deployments using SSL.
Enhanced SSL Support:
Rolling upgrades of clusters to use SSL.
mongodb-tools-support-ssl support connections to mongod (page 555) and mongos (page 571) instances
using SSL connections.
Prompt for passphrase by mongod (page 555) or mongos (page 571) at startup.
Require the use of strong SSL ciphers, with a minimum 128-bit key length for all connections. The strong-
cipher requirement prevents an old or malicious client from forcing use of a weak cipher.
MongoDB disables the http interface by default, limiting network exposure. To enable the interface, see
enabled.
See also:
New Authorization Model (page 695), SSL Certicate Hostname Validation (page 695), and
http://docs.mongodb.org/manualadministration/security-checklist.
Query Engine Improvements
MongoDB can now use index intersection to fulll queries supported by more than one index.
index-lters to limit which indexes can become the winning plan for a query.
Query Plan Cache Methods (page 129) methods to view and clear the query plans cached by the query
optimizer.
MongoDB can now use count() (page 81) with hint() (page 88). See count() (page 81) for details.
688 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Improvements
Geospatial Enhancements
2dsphere indexes version 2.
Support for geojson-multipoint, geojson-multilinestring, geojson-multipolygon, and geojson-
geometrycollection.
Support for geospatial query clauses in $or (page 393) expressions.
See also:
2dsphere Index Version 2 (page 696), $maxDistance Changes (page 698), Deprecated $uniqueDocs (page 699),
Stronger Validation of Geospatial Queries (page 699)
Index Build Enhancements
Background index build allowed on secondaries. If you initiate a background index build on a primary, the
secondaries will replicate the index build in the background.
Automatic rebuild of interrupted index builds after a restart.
If a standalone or a primary instance terminates during an index build without a clean shutdown, mongod
(page 555) now restarts the index build when the instance restarts. If the instance shuts down cleanly or if
a user kills the index build, the interrupted index builds do not automatically restart upon the restart of the
server.
If a secondary instance terminates during an index build, the mongod (page 555) instance will now restart
the interrupted index build when the instance restarts.
To disable this behavior, use the --noIndexBuildRetry (page 561) command-line option.
ensureIndex() (page 30) now wraps a new createIndex command.
The dropDups option to ensureIndex() (page 30) and createIndex is deprecated.
See also:
Enforce Index Key Length Limit (page 691)
Enhanced Sharding and Replication Administration
New cleanupOrphaned (page 298) command to remove orphaned documents from a shard.
New mergeChunks (page 302) command to combine contiguous chunks
located on a single shard. See mergeChunks (page 302) and
http://docs.mongodb.org/manualtutorial/merge-chunks-in-sharded-cluster.
New rs.printReplicationInfo() (page 174) and rs.printSlaveReplicationInfo()
(page 174) methods to provide a formatted report of the status of a replica set from the perspective of the
primary and the secondary, respectively.
Conguration Options YAML File Format
MongoDB 2.6 supports a YAML-based conguration le format in addition to the previous conguration le format.
See http://docs.mongodb.org/manualreference/configuration-options for details.
7.1. Current Stable Release 689
MongoDB Reference Manual, Release 2.6.4
Operational Changes
Storage
usePowerOf2Sizes (page 314) is now the default allocation strategy for all new collections. The new allocation
strategy uses more storage relative to total document size but results in lower levels of storage fragmentation and more
predictable storage capacity planning over time.
To use the previous exact-t allocation strategy:
For a specic collection, use collMod (page 314) with usePowerOf2Sizes (page 314) set to false.
For all new collections on an entire mongod (page 555) instance, set
newCollectionsUsePowerOf2Sizes to false.
See http://docs.mongodb.org/manualcore/storage for more information about MongoDBs storage
system.
Networking
Removed upward limit for the maxIncomingConnections for mongod (page 555) and mongos
(page 571). Previous versions capped the maximum possible maxIncomingConnections setting at
20,000 connections.
Connection pools for a mongos (page 571) instance may be used by multiple MongoDB servers. This can re-
duce the number of connections needed for high-volume workloads and reduce resource consumption in sharded
clusters.
The C++ driver now monitors replica set health with the isMaster (page 287) command instead of
replSetGetStatus (page 289). This allows the C++ driver to support systems that require authentication.
New cursor.maxTimeMS() (page 91) and corresponding maxTimeMS option for commands to specify a
time limit.
Tool Improvements
mongo (page 580) shell supports a global /etc/mongorc.js (page 584).
All MongoDB executable les (page 555) now support the --quiet option to suppress all logging output
except for error messages.
mongoimport (page 610) uses the input lename, without the le extension if any, as the collection name if
run without the -c or --collection specication.
mongoexport (page 616) can now constrain export data using --skip (page 621) and --limit (page 621),
as well as order the documents in an export using the --sort (page 621) option.
mongostat (page 624) can support the use of --rowcount (page 627) (-n (page ??)) with the
--discover (page 627) option to produce the specied number of output lines.
Add strict mode representation for data_numberlong for use by mongoexport (page 616) and
mongoimport (page 610).
MongoDB Enterprise Features
The following changes are specic to MongoDB Enterprise Editions:
690 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
MongoDB Enterprise for Windows
MongoDB Enterprise for Windows is now available. It includes support for Kerberos, SSL, and SNMP.
MongoDBEnterprise for Windows does not include LDAP support for authentication. However, MongoDBEnterprise
for Linux supports using LDAP authentication with an ActiveDirectory server.
MongoDB Enterprise for Windows includes OpenSSL version 1.0.1g.
Auditing
MongoDB Enterprise adds auditing capability for mongod (page 555) and mongos (page 571) instances. See
auditing for details.
LDAP Support for Authentication
MongoDB Enterprise provides support for proxy authentication of users. This allows ad-
ministrators to congure a MongoDB cluster to authenticate users by proxying authentica-
tion requests to a specied Lightweight Directory Access Protocol (LDAP) service. See
http://docs.mongodb.org/manualtutorial/configure-ldap-sasl-openldap and
http://docs.mongodb.org/manualtutorial/configure-ldap-sasl-activedirectory
for details.
MongoDBEnterprise for Windows does not include LDAP support for authentication. However, MongoDBEnterprise
for Linux supports using LDAP authentication with an ActiveDirectory server.
MongoDB does not support LDAP authentication in mixed sharded cluster deployments that contain both version 2.4
and version 2.6 shards. See Upgrade MongoDB to 2.6 (page 702) for upgrade instructions.
Expanded SNMP Support
MongoDB Enterprise has greatly expanded its SNMP support to provide SNMP access to nearly the full range of
metrics provided by db.serverStatus() (page 125).
See also:
SNMP Changes (page 696)
Additional Information
Changes Affecting Compatibility
Compatibility Changes in MongoDB 2.6 The following 2.6 changes can affect the compatibility with older ver-
sions of MongoDB. See Release Notes for MongoDB 2.6 (page 675) for the full list of the 2.6 changes.
Index Changes
Enforce Index Key Length Limit
Description MongoDB 2.6 implements a stronger enforcement of the limit on index key.
Creating indexes will error if an index key in an existing document exceeds the limit:
7.1. Current Stable Release 691
MongoDB Reference Manual, Release 2.6.4
db.collection.ensureIndex() (page 30), db.collection.reIndex() (page 63),
compact (page 316), and repairDatabase (page 332) will error and not create the index. Previ-
ous versions of MongoDB would create the index but not index such documents.
Because db.collection.reIndex() (page 63), compact (page 316), and repairDatabase
(page 332) drop all the indexes from a collection and then recreate them sequentially, the error from the
index key limit prevents these operations from rebuilding any remaining indexes for the collection and,
in the case of the repairDatabase (page 332) command, from continuing with the remainder of the
process.
Inserts will error:
db.collection.insert() (page 53) and other operations that perform inserts (e.g.
db.collection.save() (page 68) and db.collection.update() (page 70) with upsert
that result in inserts) will fail to insert if the new document has an indexed eld whose corresponding
index entry exceeds the limit. Previous versions of MongoDB would insert but not index such documents.
mongorestore (page 597) and mongoimport (page 610) will fail to insert if the new document has
an indexed eld whose corresponding index entry exceeds the limit.
Updates will error:
db.collection.update() (page 70) and db.collection.save() (page 68) operations on an
indexed eld will error if the updated value causes the index entry to exceed the limit.
If an existing document contains an indexed eld whose index entry exceeds the limit, updates on other
elds that result in the relocation of a document on disk will error.
Chunk Migration will fail:
Migrations will fail for a chunk that has a document with an indexed eld whose index entry exceeds the
limit.
If left unxed, the chunk will repeatedly fail migration, effectively ceasing chunk balancing for that col-
lection. Or, if chunk splits occur in response to the migration failures, this response would lead to unnec-
essarily large number of chunks and an overly large cong databases.
Secondary members of replica sets will warn:
Secondaries will continue to replicate documents with an indexed eld whose corresponding index entry
exceeds the limit on initial sync but will print warnings in the logs.
Secondaries allow index build and rebuild operations on a collection that contains an indexed eld whose
corresponding index entry exceeds the limit but with warnings in the logs.
With mixed version replica sets where the secondaries are version 2.6 and the primary is version 2.4,
secondaries will replicate documents inserted or updated on the 2.4 primary, but will print error messages
in the log if the documents contain an indexed eld whose corresponding index entry exceeds the limit.
Solution Run db.upgradeCheckAllDBs() (page 128) to nd current keys that violate this limit and correct as
appropriate. Preferably, run the test before upgrading; i.e. connect the 2.6 mongo (page 580) shell to your
MongoDB 2.4 database and run the method.
If you have an existing data set and want to disable the default index key length validation so that you can upgrade
before resolving these indexing issues, use the failIndexKeyTooLong parameter.
Index Specications Validate Field Names
Description In MongoDB 2.6, create and re-index operations fail when the index key refers to an empty eld, e.g.
"a..b" : 1 or the eld name starts with a dollar sign ($).
692 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
db.collection.ensureIndex() (page 30) will not create a new index with an invalid or empty
key name.
db.collection.reIndex() (page 63), compact (page 316), and repairDatabase (page 332)
will error if an index exists with an invalid or empty key name.
Chunk migration will fail if an index exists with an invalid or empty key name.
Previous versions of MongoDB allow the index.
Solution Run db.upgradeCheckAllDBs() (page 128) to nd current keys that violate this limit and correct as
appropriate. Preferably, run the test before upgrading; i.e. connect the 2.6 mongo (page 580) shell to your
MongoDB 2.4 database and run the method.
ensureIndex and Existing Indexes
Description db.collection.ensureIndex() (page 30) now errors:
if you try to create an existing index but with different options; e.g. in the following example, the second
db.collection.ensureIndex() (page 30) will error.
db.mycollection.ensureIndex( { x: 1 } )
db.mycollection.ensureIndex( { x: 1 }, { unique: 1 } )
if you specify an index name that already exists but the key specications differ; e.g. in the following
example, the second db.collection.ensureIndex() (page 30) will error.
db.mycollection.ensureIndex( { a: 1 }, { name: "myIdx" } )
db.mycollection.ensureIndex( { z: 1 }, { name: "myIdx" } )
Previous versions did not create the index but did not error.
Write Method Acknowledgements
Description The mongo (page 580) shell write methods db.collection.insert() (page 53),
db.collection.update() (page 70), db.collection.save() (page 68) and
db.collection.remove() (page 64) now integrate the write concern directly into the method rather
than with a separate getLastError (page 243) command to provide safe writes whether run interactively
in the mongo (page 580) shell or non-interactively in a script. In previous versions, these methods exhibited a
re-and-forget behavior.
180
Existing scripts for the mongo (page 580) shell that used these methods will now observe safe writes which
take longer than the previous re-and-forget behavior.
The write methods now return a WriteResult (page 198) object that contains the results of
the operation, including any write errors and write concern errors, and obviates the need to call
getLastError (page 243) command to get the status of the results. See db.collection.insert()
(page 53), db.collection.update() (page 70), db.collection.save() (page 68) and
db.collection.remove() (page 64) for details.
In sharded environments, mongos (page 571) no longer supports re-and-forget behavior. This limits
throughput when writing data to sharded clusters.
Solution Scripts that used these mongo (page 580) shell methods for bulk write operations with re-and-forget
behavior should use the Bulk() (page 135) methods.
180
In previous versions, when using the mongo (page 580) shell interactively, the mongo (page 580) shell automatically called the
getLastError (page 243) command after a write method to provide safe writes. Scripts, however, would observe re-and-forget behavior
in previous versions unless the scripts included an explicit call to the getLastError (page 243) command after a write method.
7.1. Current Stable Release 693
MongoDB Reference Manual, Release 2.6.4
In sharded environments, applications using any driver or mongo (page 580) shell should use Bulk()
(page 135) methods for optimal performance when inserting or modifying groups of documents.
For example, instead of:
for (var i = 1; i <= 1000000; i++) {
db.test.insert( { x : i } );
}
In MongoDB 2.6, replace with Bulk() (page 135) operation:
var bulk = db.test.initializeUnorderedBulkOp();
for (var i = 1; i <= 1000000; i++) {
bulk.insert( { x : i} );
}
bulk.execute( { w: 1 } );
Bulk method returns a BulkWriteResult (page 196) object that contains the result of the operation.
See also:
New Write Operation Protocol (page 687), Bulk() (page 135), Bulk.execute()
(page 136), db.collection.initializeUnorderedBulkOp() (page 52),
db.collection.initializeOrderedBulkOp() (page 51)
db.collection.aggregate() Change
Description The db.collection.aggregate() (page 22) method in the mongo (page 580) shell defaults to
returning a cursor to the results set. This change enables the aggregation pipeline to return result sets of any size
and requires cursor iteration to access the result set. For example:
var myCursor = db.orders.aggregate( [
{
$group: {
_id: "$cust_id",
total: { $sum: "$price" }
}
}
] );
myCursor.forEach( function(x) { printjson (x); } );
Previous versions returned a single document with a eld results that contained an array of the result set,
subject to the BSON Document size (page 658) limit. Accessing the result set in the previous versions of
MongoDB required accessing the results eld and iterating the array. For example:
var returnedDoc = db.orders.aggregate( [
{
$group: {
_id: "$cust_id",
total: { $sum: "$price" }
}
}
] );
var myArray = returnedDoc.result; // access the result field
myArray.forEach( function(x) { printjson (x); } );
694 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Solution Update scripts that currently expect db.collection.aggregate() (page 22) to return a document
with a results array to handle cursors instead.
See also:
Aggregation Enhancements (page 686), db.collection.aggregate() (page 22),
Write Concern Validation
Description Specifying a write concern that includes j: true to a mongod (page 555) or mongos (page 571)
instance running with --nojournal (page 563) option now errors. Previous versions would ignore the j:
true.
Solution Either remove the j: true specication from the write concern when issued against a mongod
(page 555) or mongos (page 571) instance with --nojournal (page 563) or run mongod (page 555) or
mongos (page 571) with journaling.
Security Changes
New Authorization Model
Description MongoDB 2.6 authorization model changes how MongoDB stores and manages user privilege informa-
tion:
Before the upgrade, MongoDB 2.6 requires at least one user in the admin database.
MongoDB versions using older models cannot create/modify users or create user-dened roles.
Solution Ensure that at least one user exists in the admin database. If no user exists in the admin database, add a
user. Then upgrade to MongoDB 2.6. Finally, upgrade the user privilege model. See Upgrade MongoDB to 2.6
(page 702).
Important: Before upgrading the authorization model, you should rst upgrade MongoDB binaries to 2.6. For
sharded clusters, ensure that all cluster components are 2.6. If there are users in any database, be sure you have
at least one user in the admin database before upgrading the MongoDB binaries.
See also:
Security Improvements (page 688)
SSL Certicate Hostname Validation
Description The SSL certicate validation now checks the Common Name (CN) and the Subject Alternative Name
(SAN) elds to ensure that either the CN or one of the SAN entries matches the hostname of the server. As a
result, if you currently use SSL and neither the CN nor any of the SAN entries of your current SSL certicates
match the hostnames, upgrading to version 2.6 will cause the SSL connections to fail.
Solution To allow for the continued use of these certicates, MongoDB provides the
allowInvalidCertificates setting. The setting is available for:
mongod (page 555) and mongos (page 571) to bypass the validation of SSL certicates on other servers
in the cluster.
mongo (page 580) shell, MongoDB tools that support SSL, and the C++ driver to bypass the validation of
server certicates.
7.1. Current Stable Release 695
MongoDB Reference Manual, Release 2.6.4
When using the allowInvalidCertificates setting, MongoDB logs as a warning the use of the invalid
certicates.
Warning: The allowInvalidCertificates setting bypasses the other certicate validation, such as
checks for expiration and valid signatures.
2dsphere Index Version 2
Description MongoDB 2.6 introduces a version 2 of the 2dsphere index. If a document lacks a 2dsphere
index eld (or the eld is null or an empty array), MongoDB does not add an entry for the document to the
2dsphere index. For inserts, MongoDB inserts the document but does not add to the 2dsphere index.
Previous version would not insert documents where the 2dsphere index eld is a null or an empty array.
For documents that lack the 2dsphere index eld, previous versions would insert and index the document.
Solution To revert to old behavior, create the 2dsphere index with { "2dsphereIndexVersion" : 1 }
to create a version 1 index. However, version 1 index cannot use the new GeoJSON geometries.
See also:
2dsphere-v2
Log Messages
Timestamp Format Change
Description Each message now starts with the timestamp format given in Time Format Changes (page 701). Previous
versions used the ctime format.
Solution MongoDB adds a new option --timeStampFormat (page 572) which supports timestamp format in
ctime (page 572), iso8601-utc (page 572), and iso8601-local (page 572) (new default).
Package Conguration Changes
Default bindIp for RPM/DEB Packages
Description In the ofcial MongoDB packages in RPM (Red Hat, CentOS, Fedora Linux, and derivatives) and DEB
(Debian, Ubuntu, and derivatives), the default bindIp value attaches MongoDB components to the localhost
interface only. These packages set this default in the default conguration le (i.e. /etc/mongodb.conf.)
Solution If you use one of these packages and have not modied the default /etc/mongodb.conf le, you will
need to set bindIp before or during the upgrade.
There is no default bindIp setting in any other ofcial MongoDB packages.
SNMP Changes
Description
The IANA enterprise identier for MongoDB changed from 37601 to 34601.
MongoDB changed the MIB eld name globalopcounts to globalOpcounts.
Solution
Users of SNMP monitoring must modify their SNMP conguration (i.e. MIB) from 37601 to 34601.
Update references to globalopcounts to globalOpcounts.
696 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Remove Method Signature Change
Description db.collection.remove() (page 64) requires a query document as a parameter. In previous ver-
sions, the method invocation without a query document deleted all documents in a collection.
Solution For existing db.collection.remove() (page 64) invocations without a query document, modify the
invocations to include an empty document db.collection.remove({}).
Update Operator Syntax Validation
Description
Update operators (e.g $set) (page 429) must specify a non-empty operand expression. For example, the
following expression is now invalid:
{ $set: { } }
Update operators (e.g $set) (page 429) cannot repeat in the update statement. For example, the following
expression is invalid:
{ $set: { a: 5 }, $set: { b: 5 } }
Updates Enforce Field Name Restrictions
Description
Updates cannot use update operators (e.g $set) (page 429) to target elds with empty eld names (i.e. "").
Updates no longer support saving eld names that contain a dot (.) or a eld name that starts with a dollar
sign ($).
Solution
For existing documents that currently have elds with empty names "", replace the whole document.
See db.collection.update() (page 70) and db.collection.save() (page 68) for details on
replacing an existing document.
Unset (page 436) or rename (page 434) existing elds with names that contain a dot (.) or that start with
a dollar sign ($). Run db.upgradeCheckAllDBs() (page 128) to nd elds whose names contain a
dot or starts with a dollar sign.
See New Write Operation Protocol (page 687) for the changes to the write operation protocol, and Insert and Update
Improvements (page 687) for the changes to the insert and update operations. Also consider the documentation of the
Restrictions on Field Names (page 663).
Query and Sort Changes
Enforce Field Name Restrictions
Description Queries cannot specify conditions on elds with names that start with a dollar sign ($).
Solution Unset (page 436) or rename (page 434) existing elds whose names start with a dollar sign ($). Run
db.upgradeCheckAllDBs() (page 128) to nd elds whose names start with a dollar sign.
7.1. Current Stable Release 697
MongoDB Reference Manual, Release 2.6.4
Sparse Index and Incomplete Results
Description If a sparse index results in an incomplete result set for queries and sort operations, MongoDB will
not use that index unless a hint() (page 88) explicitly species the index.
For example, the query { x: { $exists: false } } will no longer use a sparse index on the x eld,
unless explicitly hinted.
Solution To override the behavior to use the sparse index and return incomplete results, explicitly specify the index
with a hint() (page 88).
See sparse-index-incomplete-results for an example that details the new behavior.
sort() Specication Values
Description The sort() (page 96) method only accepts the following values for the sort keys:
1 to specify ascending order for a eld,
-1 to specify descending order for a eld, or
$meta (page 427) expression to specify sort by the text search score.
Any other value will result in an error.
Previous versions also accepted either true or false for ascending.
Solution Update sort key values that use true or false to 1.
skip() and _id Queries
Description Equality match on the _id eld obeys skip() (page 95).
Previous versions ignored skip() (page 95) when performing an equality match on the _id eld.
explain() Retains Query Plan Cache
Description explain() (page 83) no longer clears the query plans cached for that query shape.
In previous versions, explain() (page 83) would have the side effect of clearing the query plan cache for that
query shape.
See also:
Query Plan Cache Methods (page 129)
Geospatial Changes
$maxDistance Changes
Description
For $near (page 410) queries on GeoJSON data, if the queries specify a $maxDistance (page 414),
$maxDistance (page 414) must be inside of the $near (page 410) document.
In previous version, $maxDistance (page 414) could be either inside or outside the $near (page 410)
document.
$maxDistance (page 414) must be a positive value.
Solution
698 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Update any existing $near (page 410) queries on GeoJSONdata that currently have the $maxDistance
(page 414) outside the $near (page 410) document
Update any existing queries where $maxDistance (page 414) is a negative value.
Deprecated $uniqueDocs
Description MongoDB2.6 deprecates $uniqueDocs (page 416), and geospatial queries no longer return duplicated
results when a document matches the query multiple times.
Stronger Validation of Geospatial Queries
Description MongoDB 2.6 enforces a stronger validation of geospatial queries, such as validating the options or
GeoJSON specications, and errors if the geospatial query is invalid. Previous versions allowed/ignored invalid
options.
Query Operator Changes
$not Query Behavior Changes
Description
Queries with $not (page 392) expressions on an indexed eld now match:
Documents that are missing the indexed eld. Previous versions would not return these documents
using the index.
Documents whose indexed eld value is a different type than that of the specied value. Previous
versions would not return these documents using the index.
For example, if a collection orders contains the following documents:
{ _id: 1, status: "A", cust_id: "123", price: 40 }
{ _id: 2, status: "A", cust_id: "xyz", price: "N/A" }
{ _id: 3, status: "D", cust_id: "xyz" }
If the collection has an index on the price eld:
db.orders.ensureIndex( { price: 1 } )
The following query uses the index to search for documents where price is not greater than or equal to
50:
db.orders.find( { price: { $not: { $gte: 50 } } } )
In 2.6, the query returns the following documents:
{ "_id" : 3, "status" : "D", "cust_id" : "xyz" }
{ "_id" : 1, "status" : "A", "cust_id" : "123", "price" : 40 }
{ "_id" : 2, "status" : "A", "cust_id" : "xyz", "price" : "N/A" }
In previous versions, indexed plans would only return matching documents where the type of the eld
matches the type of the query predicate:
{ "_id" : 1, "status" : "A", "cust_id" : "123", "price" : 40 }
If using a collection scan, previous versions would return the same results as those in 2.6.
MongoDB 2.6 allows chaining of $not (page 392) expressions.
7.1. Current Stable Release 699
MongoDB Reference Manual, Release 2.6.4
null Comparison Queries
Description
$lt (page 388) and $gt (page 386) comparisons to null no longer match documents that are missing
the eld.
null equality conditions on array elements (e.g. "a.b": null) no longer match document missing
the nested eld a.b (e.g. a: [ 2, 3 ]).
null equality queries (i.e. field: null ) now match elds with values undefined.
$all Operator Behavior Change
Description
The $all (page 418) operator is now equivalent to an $and (page 390) operation of the specied values.
This change in behavior can allow for more matches than previous versions when passed an array of a
single nested array (e.g. [ [ "A" ] ]). When passed an array of a nested array, $all (page 418) can
now match documents where the eld contains the nested array as an element (e.g. field: [ [ "A"
], ... ]), or the eld equals the nested array (e.g. field: [ "A", "B" ]). Earlier version
could only match documents where the eld contains the nested array.
The $all (page 418) operator returns no match if the array eld contains nested arrays (e.g. field:
[ "a", ["b"] ]) and $all (page 418) on the nested eld is the element of the nested array (e.g.
"field.1": { $all: [ "b" ] }). Previous versions would return a match.
$mod Operator Enforces Strict Syntax
Description The $mod (page 398) operator now only accepts an array with exactly two elements, and errors when
passed an array with fewer or more elements. See Not Enough Elements Error (page 398) and Too Many
Elements Error (page 399) for details.
In previous versions, if passed an array with one element, the $mod (page 398) operator uses 0 as the second
element, and if passed an array with more than two elements, the $mod (page 398) ignores all but the rst two
elements. Previous versions do return an error when passed an empty array.
Solution Ensure that the array passed to $mod (page 398) contains exactly two elements:
If the array contains the a single element, add 0 as the second element.
If the array contains more than two elements, remove the extra elements.
$where Must Be Top-Level
Description $where (page 404) expressions can now only be at top level and cannot be nested within another
expression, such as $elemMatch (page 421).
Solution Update existing queries that nest $where (page 404).
$exists and notablescan If the MongoDB server has disabled collection scans, i.e. notablescan, then
$exists (page 395) queries that have no indexed solution will error.
MinKey and MaxKey Queries
Description Equality match for either MinKey or MaxKey no longer match documents missing the eld.
700 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Nested Array Queries with $elemMatch
Description The $elemMatch (page 421) query operator no longer traverses recursively into nested arrays.
For example, if a collection test contains the following document:
{ "_id": 1, "a" : [ [ 1, 2, 5 ] ] }
In 2.6, the following $elemMatch (page 421) query does not match the document:
db.test.find( { a: { $elemMatch: { $gt: 1, $lt: 5 } } } )
Solution Update existing queries that rely upon the old behavior.
Text Search Compatibility MongoDB does not support the use of the $text (page 401) query operator in mixed
sharded cluster deployments that contain both version 2.4 and version 2.6 shards. See Upgrade MongoDB to 2.6
(page 702) for upgrade instructions.
Replica Set/Sharded Cluster Validation
Shard Name Checks on Metadata Refresh
Description For sharded clusters, MongoDB 2.6 disallows a shard from refreshing the metadata if the shard name
has not been explicitly set.
For mixed sharded cluster deployments that contain both version 2.4 and version 2.6 shards, this change can
cause errors when migrating chunks from version 2.4 shards to version 2.6 shards if the shard name is unknown
to the version 2.6 shards. MongoDB does not support migrations in mixed sharded cluster deployments.
Solution Upgrade all components of the cluster to 2.6. See Upgrade MongoDB to 2.6 (page 702).
Replica Set Vote Conguration Validation
Description MongoDB now deprecates giving any replica set member more than a single vote. During conguration,
local.system.replset.members[n].votes should only have a value of 1 for voting members and
0 for non-voting members. MongoDB treats values other than 1 or 0 as a value of 1 and produces a warning
message.
Solution Update local.system.replset.members[n].votes with values other than 1 or 0 to 1 or 0 as
appropriate.
Time Format Changes MongoDB now uses iso8601-local when formatting time data in many out-
puts. This format follows the template YYYY-MM-DDTHH:mm:ss.mmm<+/-Offset>. For example,
2014-03-04T20:13:38.944-0500.
This change impacts all clients using Extended JSON in Strict mode, such as mongoexport (page 616) and the
REST and HTTP Interfaces
181
.
Other Resources
All backwards incompatible changes (JIRA)
182
.
Release Notes for MongoDB 2.6 (page 675).
181
http://docs.mongodb.org/ecosystem/tools/http-interfaces
182
https://jira.mongodb.org/issues/?jql=project%20%3D%20SERVER%20AND%20xVersion%20in%20(%222.5.0%22%2C%20%222.5.1%22%2C%20%222.5.2%22%2C%20%222.5.3%22%2C%20%222.5.4%22%2C%20%222.5.5%22%2C%20%222.6.0-
rc1%22%2C%20%222.6.0-rc2%22)%20AND%20%22Backwards%20Compatibility%22%20in%20%20(%22Major%20Change%22%2C%20%22Minor%20Change%22)%20ORDER%20BY%20votes%20DESC%2C%20issuetype%20DESC%2C%20key%20DESC
7.1. Current Stable Release 701
MongoDB Reference Manual, Release 2.6.4
Upgrade MongoDB to 2.6 (page 702) for the upgrade process.
Some changes in 2.6 can affect compatibility (page 691) and may require user actions. The 2.6 mongo (page 580)
shell provides a db.upgradeCheckAllDBs() (page 128) method to perform a check for upgrade preparedness
for some of these changes.
See Compatibility Changes in MongoDB 2.6 (page 691) for a detailed list of compatibility changes.
See also:
All Backwards incompatible changes (JIRA)
183
.
Upgrade Process
Upgrade MongoDB to 2.6 In the general case, the upgrade from MongoDB 2.4 to 2.6 is a binary-compatible drop-
in upgrade: shut down the mongod (page 555) instances and replace them with mongod (page 555) instances
running 2.6. However, before you attempt any upgrade, familiarize yourself with the content of this document,
particularly the Upgrade Recommendations and Checklists (page 702), the procedure for upgrading sharded clusters
(page 704), and the considerations for reverting to 2.4 after running 2.6 (page 707).
Upgrade Recommendations and Checklists When upgrading, consider the following:
Upgrade Requirements To upgrade an existing MongoDB deployment to 2.6, you must be running 2.4. If youre
running a version of MongoDB before 2.4, you must upgrade to 2.4 before upgrading to 2.6. See Upgrade MongoDB
to 2.4 (page 727) for the procedure to upgrade from 2.2 to 2.4.
If you use MMS Backup, ensure that youre running at least version v20131216.1 of the Backup agent before
upgrading.
Preparedness Before upgrading MongoDB always test your application in a staging environment before deploying
the upgrade to your production environment.
To begin the upgrade procedure, connect a 2.6 mongo (page 580) shell to your MongoDB 2.4 mongos (page 571) or
mongod (page 555) and run the db.upgradeCheckAllDBs() (page 128) to check your data set for compatibility.
This is a preliminary automated check. Assess and resolve all issues identied by db.upgradeCheckAllDBs()
(page 128).
Some changes in MongoDB 2.6 require manual checks and intervention. See Compatibility Changes in MongoDB 2.6
(page 691) for an explanation of these changes. Resolve all incompatibilities in your deployment before continuing.
Authentication MongoDB 2.6 includes signicant changes to the authorization model, which requires changes to
the way that MongoDB stores users credentials. As a result, in addition to upgrading MongoDB processes, if your
deployment uses authentication and authorization, after upgrading all MongoDB process to 2.6 you must also upgrade
the authorization model.
After you begin to upgrade a MongoDB deployment that uses authentication to 2.6, you cannot modify existing user
data until you complete the authorization user schema upgrade (page 706).
Before beginning the upgrade process for a deployment that uses authentication and authorization:
Ensure that at least one user exists in the admin database.
183
https://jira.mongodb.org/issues/?jql=project%20%3D%20SERVER%20AND%20xVersion%20in%20(%222.5.0%22%2C%20%222.5.1%22%2C%20%222.5.2%22%2C%20%222.5.3%22%2C%20%222.5.4%22%2C%20%222.5.5%22%2C%20%222.6.0-
rc1%22%2C%20%222.6.0-rc2%22%2C%20%222.6.0-rc3%22)%20AND%20%22Backwards%20Compatibility%22%20in%20(%20%22Minor%20Change%22%2C%22Major%20Change%22%20)%20ORDER%20BY%20votes%20DESC%2C%20issuetype%20DESC%2C%20key%20DESC
702 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
If your application performs CRUD operations on the <database>.system.users collection or uses a
db.addUser() (page 148)-like method, then you must upgrade those drivers (i.e. client libraries) before
mongod (page 555) or mongos (page 571) instances.
You must fully complete the upgrade procedure for all MongoDB processes before upgrading the authorization
model.
See Upgrade User Authorization Data to 2.6 Format (page 706) for a complete discussion of the upgrade procedure
for the authorization model including additional requirements and procedures.
Downgrade Limitations Once upgraded to MongoDB 2.6, you cannot downgrade to any version earlier than Mon-
goDB 2.4. If you created text or 2dsphere indexes while running 2.6, you can only downgrade to MongoDB
2.4.10 or later.
Package Upgrades If you installed MongoDB from the MongoDB apt or yum repositories, upgrade to 2.6 using
the package manager.
For Debian, Ubuntu, and related operating systems, type these commands:
sudo apt-get update
sudo apt-get install mongodb-org
For Red Hat Enterprise, CentOS, Fedora, or Amazon Linux:
sudo yum install mongodb-org
If you did not install the mongodb-org package, and installed a subset of MongoDB components replace
mongodb-org in the commands above with the appropriate package names.
See installation instructions for Ubuntu, RHEL, Debian, or other Linux Systems for a list of the available
packages and complete MongoDB installation instructions.
Upgrade MongoDB Processes
Upgrade Standalone mongod Instance to MongoDB 2.6 The following steps outline the procedure to upgrade a
standalone mongod (page 555) from version 2.4 to 2.6. To upgrade from version 2.2 to 2.6, upgrade to version 2.4
(page 727) rst, and then follow the procedure to upgrade from 2.4 to 2.6.
1. Download binaries of the latest release in the 2.6 series from the MongoDB Download Page
184
. See
http://docs.mongodb.org/manualinstallation for more information.
2. Shut down your mongod (page 555) instance. Replace the existing binary with the 2.6 mongod (page 555)
binary and restart mongod (page 555).
Upgrade a Replica Set to 2.6 The following steps outline the procedure to upgrade a replica set from MongoDB
2.4 to MongoDB 2.6. To upgrade from MongoDB 2.2 to 2.6, upgrade all members of the replica set to version 2.4
(page 727) rst, and then follow the procedure to upgrade from MongoDB 2.4 to 2.6.
You can upgrade from MongoDB 2.4 to 2.6 using a rolling upgrade to minimize downtime by upgrading the mem-
bers individually while the other members are available:
184
http://www.mongodb.org/downloads
7.1. Current Stable Release 703
MongoDB Reference Manual, Release 2.6.4
Step 1: Upgrade secondary members of the replica set. Upgrade the secondary members of the set one at a time
by shutting down the mongod (page 555) and replacing the 2.4 binary with the 2.6 binary. After upgrading a mongod
(page 555) instance, wait for the member to recover to SECONDARY state before upgrading the next instance. To
check the members state, issue rs.status() (page 177) in the mongo (page 580) shell.
Step 2: Step down the replica set primary. Use rs.stepDown() (page 177) in the mongo (page 580) shell to
step down the primary and force the set to failover. rs.stepDown() (page 177) expedites the failover procedure
and is preferable to shutting down the primary directly.
Step 3: Upgrade the primary. When rs.status() (page 177) shows that the primary has stepped down and
another member has assumed PRIMARY state, shut down the previous primary and replace the mongod (page 555)
binary with the 2.6 binary and start the new instance.
Replica set failover is not instant but will render the set unavailable accept writes until the failover process completes.
Typically this takes 30 seconds or more: schedule the upgrade procedure during a scheduled maintenance window.
Upgrade a Sharded Cluster to 2.6 Only upgrade sharded clusters to 2.6 if all members of the cluster are currently
running instances of 2.4. The only supported upgrade path for sharded clusters running 2.2 is via 2.4. The upgrade
process checks all components of the cluster and will produce warnings if any component is running version 2.2.
Considerations The upgrade process does not require any downtime. However, while you upgrade the sharded
cluster, ensure that clients do not make changes to the collection meta-data. For example, during the upgrade, do not
do any of the following:
sh.enableSharding() (page 185)
sh.shardCollection() (page 188)
sh.addShard() (page 182)
db.createCollection() (page 106)
db.collection.drop() (page 28)
db.dropDatabase() (page 113)
any operation that creates a database
any other operation that modies the cluster metadata in any way. See
http://docs.mongodb.org/manualreference/sharding for a complete
list of sharding commands. Note, however, that not all commands on the
http://docs.mongodb.org/manualreference/sharding page modies the cluster meta-data.
Upgrade Sharded Clusters Optional but Recommended. As a precaution, take a backup of the config database
before upgrading the sharded cluster.
Step 1: Disable the Balancer. Turn off the balancer in the sharded cluster, as described in sharding-balancing-
disable-temporarily.
Step 2: Upgrade the clusters meta data. Start a single 2.6 mongos (page 571) instance with the configDB
pointing to the clusters cong servers and with the --upgrade option.
To run a mongos (page 571) with the --upgrade option, you can upgrade an existing mongos (page 571) instance
to 2.6, or if you need to avoid reconguring a production mongos (page 571) instance, you can use a new 2.6 mongos
(page 571) that can reach all the cong servers.
704 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
To upgrade the meta data, run:
mongos --configdb <configDB string> --upgrade
You can include the --logpath option to output the log messages to a le instead of the standard out-
put. Also include any other options required to start mongos (page 571) instances in your cluster, such as
--sslOnNormalPorts or --sslPEMKeyFile.
The mongos (page 571) will exit upon completion of the --upgrade process.
The upgrade will prevent any chunk moves or splits from occurring during the upgrade process. If the data les have
many sharded collections or if failed processes hold stale locks, acquiring the locks for all collections can take seconds
or minutes. Watch the log for progress updates.
Step 3: Ensure mongos --upgrade process completes successfully. The mongos (page 571) will exit upon
completion of the meta data upgrade process. If successful, the process will log the following messages:
upgrade of config server to v5 successful
Config database is at version v5
After a successful upgrade, restart the mongos (page 571) instance. If mongos (page 571) fails to start, check the
log for more information.
If the mongos (page 571) instance loses its connection to the cong servers during the upgrade or if the upgrade is
otherwise unsuccessful, you may always safely retry the upgrade.
Step 4: Upgrade the remaining mongos instances to v2.6. Upgrade and restart without the --upgrade
(page 575) option the other mongos (page 571) instances in the sharded cluster. After upgrading all the mongos
(page 571), see Complete Sharded Cluster Upgrade (page 705) for information on upgrading the other cluster compo-
nents.
Complete Sharded Cluster Upgrade After you have successfully upgraded all mongos (page 571) instances, you
can upgrade the other instances in your MongoDB deployment.
Warning: Do not upgrade mongod (page 555) instances until after you have upgraded all mongos (page 571)
instances.
While the balancer is still disabled, upgrade the components of your sharded cluster in the following order:
Upgrade all 3 mongod (page 555) cong server instances, leaving the rst system in the mongos
--configdb argument to upgrade last.
Upgrade each shard, one at a time, upgrading the mongod (page 555) secondaries before running
replSetStepDown (page 294) and upgrading the primary of each shard.
When this process is complete, re-enable the balancer.
Upgrade Procedure Once upgraded to MongoDB 2.6, you cannot downgrade to any version earlier than MongoDB
2.4. If you have text or 2dsphere indexes, you can only downgrade to MongoDB 2.4.10 or later.
Except as described on this page, moving between 2.4 and 2.6 is a drop-in replacement:
7.1. Current Stable Release 705
MongoDB Reference Manual, Release 2.6.4
Step 1: Stop the existing mongod instance. For example, on Linux, run 2.4 mongod (page 555) with the
--shutdown (page 564) option as follows:
mongod --dbpath /var/mongod/data --shutdown
Replace /var/mongod/data with your MongoDB dbPath. See also the terminate-mongod-processes for alter-
nate methods of stopping a mongod (page 555) instance.
Step 2: Start the new mongod instance. Ensure you start the 2.6 mongod (page 555) with the same dbPath:
mongod --dbpath /var/mongod/data
Replace /var/mongod/data with your MongoDB dbPath.
Upgrade User Authorization Data to 2.6 Format MongoDB 2.6 includes signicant changes to the authorization
model, which requires changes to the way that MongoDBstores users credentials. As a result, in addition to upgrading
MongoDB processes, if your deployment uses authentication and authorization, after upgrading all MongoDB process
to 2.6 you must also upgrade the authorization model.
Considerations
Complete all other Upgrade Requirements Before upgrading the authorization model, you should rst upgrade
MongoDB binaries to 2.6. For sharded clusters, ensure that all cluster components are 2.6. If there are users in any
database, be sure you have at least one user in the admin database before upgrading the MongoDB binaries.
Timing Because downgrades are more difcult after you upgrade the user authorization model, once you upgrade
the MongoDB binaries to version 2.6, allow your MongoDB deployment to run a day or two without upgrading the
user authorization model.
This allows 2.6 some time to burn in and decreases the likelihood of downgrades occurring after the user privilege
model upgrade. The user authentication and access control will continue to work as it did in 2.4, but it will be
impossible to create or modify users or to use user-dened roles until you run the authorization upgrade.
If you decide to upgrade the user authorization model immediately instead of waiting the recommended burn in
period, then for sharded clusters, you must wait at least 10 seconds after upgrading the sharded clusters to run the
authorization upgrade script.
Replica Sets For a replica set, it is only necessary to run the upgrade process on the primary as the changes will
automatically replicate to the secondaries.
Sharded Clusters For a sharded cluster, connect to a mongos (page 571) and run the upgrade procedure to upgrade
the clusters authorization data. By default, the procedure will upgrade the authorization data of the shards as well.
To override this behavior, run the upgrade command with the additional parameter upgradeShards: false.
If you choose to override, you must run the upgrade procedure on the mongos (page 571) rst, and then run the
procedure on the primary members of each shard.
For a sharded cluster, do not run the upgrade process directly against the config servers. Instead, perform the
upgrade process using one mongos (page 571) instance to interact with the cong database.
Requirements To upgrade the authorization model, you must have a user in the admin database with the role
userAdminAnyDatabase.
706 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Procedure
Step 1: Connect to MongoDB instance. Connect and authenticate to the mongod (page 555) instance for
a single deployment or a mongos (page 571) for a sharded cluster as an admin database user with the role
userAdminAnyDatabase.
Step 2: Upgrade authorization schema. Use the authSchemaUpgrade (page 261) command in the admin
database to update the user data using the mongo (page 580) shell.
Run authSchemaUpgrade command.
db.getSiblingDB("admin").runCommand({authSchemaUpgrade: 1 });
In case of error, you may safely rerun the authSchemaUpgrade (page 261) command.
Sharded cluster authSchemaUpgrade consideration. For a sharded cluster, authSchemaUpgrade
(page 261) will upgrade the authorization data of the shards as well and the upgrade is complete. You can, however,
override this behavior by including upgradeShards: false in the command, as in the following example:
db.getSiblingDB("admin").runCommand({authSchemaUpgrade: 1,
upgradeShards: false });
If you override the behavior, after running authSchemaUpgrade (page 261) on a mongos (page 571) instance,
you will need to connect to the primary for each shard and repeat the upgrade process after upgrading on the mongos
(page 571).
Result All users in a 2.6 system are stored in the admin.system.users (page 655) collection. To manipulate
these users, use the user management methods (page 148).
The upgrade procedure copies the version 2.4 admin.system.users collection to
admin.system.backup_users.
The upgrade procedure leaves the version 2.4 <database>.system.users collection(s) intact.
Downgrade MongoDB from 2.6 Before you attempt any downgrade, familiarize yourself with the content of this
document, particularly the Downgrade Recommendations and Checklist (page 707) and the procedure for downgrading
sharded clusters (page 712).
Downgrade Recommendations and Checklist When downgrading, consider the following:
Downgrade Path Once upgraded to MongoDB 2.6, you cannot downgrade to any version earlier than MongoDB
2.4. If you created text or 2dsphere indexes while running 2.6, you can only downgrade to MongoDB 2.4.10 or
later.
Preparedness
Remove or downgrade version 2 text indexes (page 710) before downgrading MongoDB 2.6 to 2.4.
Remove or downgrade version 2 2dsphere indexes (page 711) before downgrading MongoDB 2.6 to 2.4.
Downgrade 2.6 User Authorization Model (page 708). If you have upgraded to the 2.6 user authorization model,
you must downgrade the user model to 2.4 before downgrading MongoDB 2.6 to 2.4.
7.1. Current Stable Release 707
MongoDB Reference Manual, Release 2.6.4
Procedures Follow the downgrade procedures:
To downgrade sharded clusters, see Downgrade a 2.6 Sharded Cluster (page 712).
To downgrade replica sets, see Downgrade a 2.6 Replica Set (page 711).
To downgrade a standalone MongoDB instance, see Downgrade 2.6 Standalone mongod Instance (page 711).
Downgrade 2.6 User Authorization Model If you have upgraded to the 2.6 user authorization model, you must
rst downgrade the user authorization model to 2.4 before before downgrading MongoDB 2.6 to 2.4.
Considerations
For a replica set, it is only necessary to run the downgrade process on the primary as the changes will automati-
cally replicate to the secondaries.
For sharded clusters, although the procedure lists the downgrade of the clusters authorization data rst, you
may downgrade the authorization data of the cluster or shards rst.
You must have the admin.system.backup_users and admin.system.new_users collections cre-
ated during the upgrade process.
Important. The downgrade process returns the user data to its state prior to upgrading to 2.6 authorization
model. Any changes made to the user/role data using the 2.6 users model will be lost.
Access Control Prerequisites To downgrade the authorization model, you must connect as a user with the following
privileges:
{ resource: { db: "admin", collection: "system.new_users" }, actions: [ "find", "insert", "update" ] }
{ resource: { db: "admin", collection: "system.backup_users" }, actions: [ "find" ] }
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find", "remove", "insert"] }
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find", "update" ] }
If no user exists with the appropriate privileges, create an authorization model downgrade user:
Step 1: Connect as user with privileges to manage users and roles. Connect and authenticate as a user with
userAdminAnyDatabase.
Step 2: Create a role with required privileges. Using the db.createRole (page 159) method, create a role
with the required privileges.
use admin
db.createRole(
{
role: "downgradeAuthRole",
privileges: [
{ resource: { db: "admin", collection: "system.new_users" }, actions: [ "find", "insert", "update" ] },
{ resource: { db: "admin", collection: "system.backup_users" }, actions: [ "find" ] },
{ resource: { db: "admin", collection: "system.users" }, actions: [ "find", "remove", "insert"] },
{ resource: { db: "admin", collection: "system.version" }, actions: [ "find", "update" ] }
],
roles: [ ]
}
)
708 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Step 3: Create a user with the new role. Create a user and assign the user the downgradeRole.
use admin
db.createUser(
{
user: "downgradeAuthUser",
pwd: "somePass123",
roles: [ { role: "downgradeAuthRole", db: "admin" } ]
}
)
Note: Instead of creating a new user, you can also grant the role to an existing user. See
db.grantRolesToUser() (page 154) method.
Step 4: Authenticate as the new user. Authenticate as the newly created user.
use admin
db.auth( "downgradeAuthUser", "somePass123" )
The method returns 1 upon successful authentication.
Procedure The following downgrade procedure requires <database>.system.users collections used in ver-
sion 2.4. to be intact for non-admin databases.
Step 1: Connect and authenticate to MongoDB instance. Connect and authenticate to the mongod (page 555)
instance for a single deployment or a mongos (page 571) for a sharded cluster with the appropriate privileges. See
Access Control Prerequisites (page 708) for details.
Step 2: Create backup of 2.6 admin.system.users collection. Copy all documents in the
admin.system.users (page 655) collection to the admin.system.new_users collection:
db.getSiblingDB("admin").system.users.find().forEach( function(userDoc) {
status = db.getSiblingDB("admin").system.new_users.save( userDoc );
if (status.hasWriteError()) {
print(status.writeError);
}
}
);
Step 3: Update the version document for the authSchema.
db.getSiblingDB("admin").system.version.update(
{ _id: "authSchema" },
{ $set: { currentVersion: 2 } }
);
The method returns a WriteResult (page 198) object with the status of the operation. Upon successful update, the
WriteResult (page 198) object should have "nModified" equal to 1.
Step 4: Remove existing documents from the admin.system.users collection.
db.getSiblingDB("admin").system.users.remove( {} )
The method returns a WriteResult (page 198) object with the number of documents removed in the "nRemoved"
eld.
7.1. Current Stable Release 709
MongoDB Reference Manual, Release 2.6.4
Step 5: Copy documents from the admin.system.backup_users collection. Copy all documents from the
admin.system.backup_users, created during the 2.6 upgrade, to admin.system.users.
db.getSiblingDB("admin").system.backup_users.find().forEach(
function (userDoc) {
status = db.getSiblingDB("admin").system.users.insert( userDoc );
if (status.hasWriteError()) {
print(status.writeError);
}
}
);
Step 6: Update the version document for the authSchema.
db.getSiblingDB("admin").system.version.update(
{ _id: "authSchema" },
{ $set: { currentVersion: 1 } }
)
For a sharded cluster, repeat the downgrade process by connecting to the primary replica set member for each shard.
Note: The clusters mongos (page 571) instances will fail to detect the authorization model downgrade until
the user cache is refreshed. You can run invalidateUserCache (page 277) on each mongos (page 571) in-
stance to refresh immediately, or you can wait until the cache is refreshed automatically at the end of the user
cache invalidation interval. To run invalidateUserCache (page 277), you must have privilege
with invalidateUserCache action, which is granted by userAdminAnyDatabase and hostManager
roles.
Result The downgrade process returns the user data to its state prior to upgrading to 2.6 authorization model. Any
changes made to the user/role data using the 2.6 users model will be lost.
Downgrade Updated Indexes
Text Index Version Check If you have version 2 text indexes (i.e. the default version for text indexes in MongoDB
2.6), drop the version 2 text indexes before downgrading MongoDB. After the downgrade, enable text search and
recreate the dropped text indexes.
To determine the version of your text indexes, run db.collection.getIndexes() (page 45) to view index
specications. For text indexes, the method returns the version information in the eld textIndexVersion. For
example, the following shows that the text index on the quotes collection is version 2.
{
"v" : 1,
"key" : {
"_fts" : "text",
"_ftsx" : 1
},
"name" : "quote_text_translation.quote_text",
"ns" : "test.quotes",
"weights" : {
"quote" : 1,
"translation.quote" : 1
},
"default_language" : "english",
"language_override" : "language",
710 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
"textIndexVersion" : 2
}
2dsphere Index Version Check If you have version 2 2dsphere indexes (i.e. the default version for 2dsphere
indexes in MongoDB 2.6), drop the version 2 2dsphere indexes before downgrading MongoDB. After the down-
grade, recreate the 2dsphere indexes.
To determine the version of your 2dsphere indexes, run db.collection.getIndexes() (page 45) to
view index specications. For 2dsphere indexes, the method returns the version information in the eld
2dsphereIndexVersion. For example, the following shows that the 2dsphere index on the locations
collection is version 2.
{
"v" : 1,
"key" : {
"geo" : "2dsphere"
},
"name" : "geo_2dsphere",
"ns" : "test.locations",
"sparse" : true,
"2dsphereIndexVersion" : 2
}
Downgrade MongoDB Processes
Downgrade 2.6 Standalone mongod Instance The following steps outline the procedure to downgrade a stan-
dalone mongod (page 555) from version 2.6 to 2.4.
1. Download binaries of the latest release in the 2.4 series from the MongoDB Download Page
185
. See
http://docs.mongodb.org/manualinstallation for more information.
2. Shut down your mongod (page 555) instance. Replace the existing binary with the 2.4 mongod (page 555)
binary and restart mongod (page 555).
Downgrade a 2.6 Replica Set The following steps outline a rolling downgrade process for the replica set. The
rolling downgrade process minimizes downtime by downgrading the members individually while the other members
are available:
Step 1: Downgrade each secondary member, one at a time. For each secondary in a replica set:
Replace and restart secondary mongod instances. First, shut down the mongod (page 555), then replace these
binaries with the 2.4 binary and restart mongod (page 555). See terminate-mongod-processes for instructions on
safely terminating mongod (page 555) processes.
Allow secondary to recover. Wait for the member to recover to SECONDARY state before upgrading the next sec-
ondary.
To check the members state, use the rs.status() (page 177) method in the mongo (page 580) shell.
185
http://www.mongodb.org/downloads
7.1. Current Stable Release 711
MongoDB Reference Manual, Release 2.6.4
Step 2: Step down the primary. Use rs.stepDown() (page 177) in the mongo (page 580) shell to step down
the primary and force the normal failover procedure.
rs.stepDown()
rs.stepDown() (page 177) expedites the failover procedure and is preferable to shutting down the primary directly.
Step 3: Replace and restart former primary mongod. When rs.status() (page 177) shows that the primary
has stepped down and another member has assumed PRIMARY state, shut down the previous primary and replace the
mongod (page 555) binary with the 2.4 binary and start the new instance.
Replica set failover is not instant but will render the set unavailable to writes and interrupt reads until the failover pro-
cess completes. Typically this takes 10 seconds or more. You may wish to plan the downgrade during a predetermined
maintenance window.
Downgrade a 2.6 Sharded Cluster
Requirements While the downgrade is in progress, you cannot make changes to the collection meta-data. For
example, during the downgrade, do not do any of the following:
sh.enableSharding() (page 185)
sh.shardCollection() (page 188)
sh.addShard() (page 182)
db.createCollection() (page 106)
db.collection.drop() (page 28)
db.dropDatabase() (page 113)
any operation that creates a database
any other operation that modies the cluster meta-data in any way. See
http://docs.mongodb.org/manualreference/sharding for a complete
list of sharding commands. Note, however, that not all commands on the
http://docs.mongodb.org/manualreference/sharding page modies the cluster meta-data.
Procedure The downgrade procedure for a sharded cluster reverses the order of the upgrade procedure.
1. Turn off the balancer in the sharded cluster, as described in sharding-balancing-disable-temporarily.
2. Downgrade each shard, one at a time. For each shard,
(a) Downgrade the mongod (page 555) secondaries before downgrading the primary.
(b) To downgrade the primary, run replSetStepDown (page 294) and downgrade.
3. Downgrade all 3 mongod (page 555) cong server instances, leaving the rst system in the mongos
--configdb argument to downgrade last.
4. Downgrade and restart each mongos (page 571), one at a time. The downgrade process is a binary drop-in
replacement.
5. Turn on the balancer, as described in sharding-balancing-enable.
712 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Downgrade Procedure Once upgraded to MongoDB 2.6, you cannot downgrade to any version earlier than Mon-
goDB 2.4. If you have text or 2dsphere indexes, you can only downgrade to MongoDB 2.4.10 or later.
Except as described on this page, moving between 2.4 and 2.6 is a drop-in replacement:
Step 1: Stop the existing mongod instance. For example, on Linux, run 2.6 mongod (page 555) with the
--shutdown (page 564) option as follows:
mongod --dbpath /var/mongod/data --shutdown
Replace /var/mongod/data with your MongoDB dbPath. See also the terminate-mongod-processes for alter-
nate methods of stopping a mongod (page 555) instance.
Step 2: Start the new mongod instance. Ensure you start the 2.4 mongod (page 555) with the same dbPath:
mongod --dbpath /var/mongod/data
Replace /var/mongod/data with your MongoDB dbPath.
See Upgrade MongoDB to 2.6 (page 702) for full upgrade instructions.
Download
To download MongoDB 2.6, go to the downloads page
186
.
Other Resources
All JIRA issues resolved in 2.6
187
.
All Third Party License Notices
188
.
7.2 Previous Stable Releases
7.2.1 Release Notes for MongoDB 2.4
March 19, 2013
MongoDB 2.4 includes enhanced geospatial support, switch to V8 JavaScript engine, security enhancements, and text
search (beta) and hashed index.
Minor Releases
2.4 Changelog
2.4.11 - Changes
Security: Potential information leak (SERVER-14268
189
)
186
http://www.mongodb.org/downloads
187
https://jira.mongodb.org/secure/IssueNavigator.jspa?reset=true&jqlQuery=project+%3D+SERVER+AND+xVersion+in+%28%222.5.0%22%2C+%222.5.1%22%2C+%222.5.2%22%2C+%222.5.3%22%2C+%222.5.4%22%2C+%222.5.5%22%2C+%222.6.0-
rc1%22%2C+%222.6.0-rc2%22%2C+%222.6.0-rc3%22%29
188
https://github.com/mongodb/mongo/blob/v2.6/distsrc/THIRD-PARTY-NOTICES
189
https://jira.mongodb.org/browse/SERVER-14268
7.2. Previous Stable Releases 713
MongoDB Reference Manual, Release 2.6.4
Replication: _id with $prefix eld causes replication failure due to unvalidated insert (SERVER-12209
190
)
Sharding: Invalid access: seg fault in SplitChunkCommand::run (SERVER-14342
191
)
Indexing: Creating descending index on _id can corrupt namespace (SERVER-14833
192
)
Text Search: Updates to documents with text-indexed elds may lead to incorrect entries (SERVER-14738
193
)
Build: Add SCons ag to override treating all warnings as errors (SERVER-13724
194
)
Packaging: Fix mongodb enterprise 2.4 init script to allow multiple processes per host (SERVER-14336
195
)
JavaScript: Do not store native function pointer as a property in function prototype (SERVER-14254
196
)
2.4.10 - Changes
Indexes: Fixed issue that can cause index corruption when building indexes concurrently (SERVER-12990
197
)
Indexes: Fixed issue that can cause index corruption when shutting down secondary node during index build
(SERVER-12956
198
)
Indexes: Mongod now recognizes incompatible future text and geo index versions and exits gracefully
(SERVER-12914
199
)
Indexes: Fixed issue that can cause secondaries to fail replication when building the same index multiple times
concurrently (SERVER-12662
200
)
Indexes: Fixed issue that can cause index corruption on the tenth index in a collection if the index build fails
(SERVER-12481
201
)
Indexes: Introduced versioning for text and geo indexes to ensure backwards compatibility (SERVER-12175
202
)
Indexes: Disallowed building indexes on the system.indexes collection, which can lead to initial sync failure on
secondaries (SERVER-10231
203
)
Sharding: Avoid frequent immediate balancer retries when cong servers are out of sync (SERVER-12908
204
)
Sharding: Add indexes to locks collection on cong servers to avoid long queries in case of large numbers of
collections (SERVER-12548
205
)
Sharding: Fixed issue that can corrupt the cong metadata cache when sharding collections concurrently
(SERVER-12515
206
)
Sharding: Dont move chunks created on collections with a hashed shard key if the collection already contains
data (SERVER-9259
207
)
190
https://jira.mongodb.org/browse/SERVER-12209
191
https://jira.mongodb.org/browse/SERVER-14342
192
https://jira.mongodb.org/browse/SERVER-14833
193
https://jira.mongodb.org/browse/SERVER-14738
194
https://jira.mongodb.org/browse/SERVER-13724
195
https://jira.mongodb.org/browse/SERVER-14336
196
https://jira.mongodb.org/browse/SERVER-14254
197
https://jira.mongodb.org/browse/SERVER-12990
198
https://jira.mongodb.org/browse/SERVER-12956
199
https://jira.mongodb.org/browse/SERVER-12914
200
https://jira.mongodb.org/browse/SERVER-12662
201
https://jira.mongodb.org/browse/SERVER-12481
202
https://jira.mongodb.org/browse/SERVER-12175
203
https://jira.mongodb.org/browse/SERVER-10231
204
https://jira.mongodb.org/browse/SERVER-12908
205
https://jira.mongodb.org/browse/SERVER-12548
206
https://jira.mongodb.org/browse/SERVER-12515
207
https://jira.mongodb.org/browse/SERVER-9259
714 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Replication: Fixed issue where node appears to be down in a replica set during a compact operation (SERVER-
12264
208
)
Replication: Fixed issue that could cause delays in elections when a node is not vetoing an election (SERVER-
12170
209
)
Replication: Step down all primaries if multiple primaries are detected in replica set to ensure correct election
result (SERVER-10793
210
)
Replication: Upon clock skew detection, secondaries will switch to sync directly from the primary to avoid sync
cycles (SERVER-8375
211
)
Runtime: The SIGXCPU signal is now caught and mongod writes a log message and exits gracefully (SERVER-
12034
212
)
Runtime: Fixed issue where mongod fails to start on Linux when /sys/dev/block directory is not readable
(SERVER-9248
213
)
Windows: No longer zero-ll newly allocated les on systems other than Windows 7 or Windows Server 2008
R2 (SERVER-8480
214
)
GridFS: Chunk size is decreased to 255 KB (from 256 KB) to avoid overhead with usePowerOf2Sizes option
(SERVER-13331
215
)
SNMP: Fixed MIB le validation under smilint (SERVER-12487
216
)
Shell: Fixed issue in V8 memory allocation that could cause long-running shell commands to crash (SERVER-
11871
217
)
Shell: Fixed memory leak in the md5sumFile shell utility method (SERVER-11560
218
)
Previous Releases
All 2.4.9 improvements
219
.
All 2.4.8 improvements
220
.
All 2.4.7 improvements
221
.
All 2.4.6 improvements
222
.
All 2.4.5 improvements
223
.
All 2.4.4 improvements
224
.
All 2.4.3 improvements
225
.
208
https://jira.mongodb.org/browse/SERVER-12264
209
https://jira.mongodb.org/browse/SERVER-12170
210
https://jira.mongodb.org/browse/SERVER-10793
211
https://jira.mongodb.org/browse/SERVER-8375
212
https://jira.mongodb.org/browse/SERVER-12034
213
https://jira.mongodb.org/browse/SERVER-9248
214
https://jira.mongodb.org/browse/SERVER-8480
215
https://jira.mongodb.org/browse/SERVER-13331
216
https://jira.mongodb.org/browse/SERVER-12487
217
https://jira.mongodb.org/browse/SERVER-11871
218
https://jira.mongodb.org/browse/SERVER-11560
219
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.9%22%20AND%20project%20%3D%20SERVER
220
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.8%22%20AND%20project%20%3D%20SERVER
221
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.7%22%20AND%20project%20%3D%20SERVER
222
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.6%22%20AND%20project%20%3D%20SERVER
223
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.5%22%20AND%20project%20%3D%20SERVER
224
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.4%22%20AND%20project%20%3D%20SERVER
225
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.3%22%20AND%20project%20%3D%20SERVER
7.2. Previous Stable Releases 715
MongoDB Reference Manual, Release 2.6.4
All 2.4.2 improvements
226
All 2.4.1 improvements
227
.
2.4.11 August 18, 2014
Fixed potential information leak: SERVER-14268
228
.
Resolved issue were an _id with a $prefix eld caused replication failure due to unvalidated insert SERVER-
12209
229
.
Addressed issue where updates to documents with text-indexed elds could lead to incorrect entries SERVER-
14738
230
.
Resolved issue where creating descending index on _id could corrupt namespace SERVER-14833
231
.
2.4.11 Changelog (page 713).
All 2.4.11 improvements
232
.
2.4.10 April 4, 2014
Performs fast le allocation on Windows when available SERVER-8480
233
.
Start elections if more than one primary is detected SERVER-10793
234
.
Changes to allow safe downgrading from v2.6 to v2.4 SERVER-12914
235
, SERVER-12175
236
.
Fixes for edge cases in index creation SERVER-12481
237
, SERVER-12956
238
.
2.4.10 Changelog (page 714).
All 2.4.10 improvements
239
.
2.4.9 January 10, 2014
Fix for instances where mongos (page 571) incorrectly reports a successful write SERVER-12146
240
.
Make non-primary read preferences consistent with slaveOK versioning logic SERVER-11971
241
.
Allow new sharded cluster connections to read from secondaries when primary is down SERVER-7246
242
.
All 2.4.9 improvements
243
.
226
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.2%22%20AND%20project%20%3D%20SERVER
227
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.1%22%20AND%20project%20%3D%20SERVER
228
https://jira.mongodb.org/browse/SERVER-14268
229
https://jira.mongodb.org/browse/SERVER-12209
230
https://jira.mongodb.org/browse/SERVER-14738
231
https://jira.mongodb.org/browse/SERVER-14833
232
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.11%22%20AND%20project%20%3D%20SERVER
233
https://jira.mongodb.org/browse/SERVER-8480
234
https://jira.mongodb.org/browse/SERVER-10793
235
https://jira.mongodb.org/browse/SERVER-12914
236
https://jira.mongodb.org/browse/SERVER-12175
237
https://jira.mongodb.org/browse/SERVER-12481
238
https://jira.mongodb.org/browse/SERVER-12956
239
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.10%22%20AND%20project%20%3D%20SERVER
240
https://jira.mongodb.org/browse/SERVER-12146
241
https://jira.mongodb.org/browse/SERVER-11971
242
https://jira.mongodb.org/browse/SERVER-7246
243
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.9%22%20AND%20project%20%3D%20SERVER
716 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
2.4.8 November 1, 2013
Increase future compatibility for 2.6 authorization features SERVER-11478
244
.
Fix dbhash cache issue for cong servers SERVER-11421
245
.
All 2.4.8 improvements
246
.
2.4.7 October 21, 2013
Fixed over-aggressive caching of V8 Isolates SERVER-10596
247
.
Removed extraneous initial count during mapReduce SERVER-9907
248
.
Cache results of dbhash command SERVER-11021
249
.
Fixed memory leak in aggregation SERVER-10554
250
.
All 2.4.7 improvements
251
.
2.4.6 August 20, 2013
Fix for possible loss of documents during the chunk migration process if a document in the chunk is very large
SERVER-10478
252
.
Fix for C++ client shutdown issues SERVER-8891
253
.
Improved replication robustness in presence of high network latency SERVER-10085
254
.
Improved Solaris support SERVER-9832
255
, SERVER-9786
256
, and SERVER-7080
257
.
All 2.4.6 improvements
258
.
2.4.5 July 3, 2013
Fix for CVE-2013-4650 Improperly grant user system privileges on databases other than local SERVER-
9983
259
.
Fix for CVE-2013-3969 Remotely triggered segmentation fault in Javascript engine SERVER-9878
260
.
Fix to prevent identical background indexes from being built SERVER-9856
261
.
244
https://jira.mongodb.org/browse/SERVER-11478
245
https://jira.mongodb.org/browse/SERVER-11421
246
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.8%22%20AND%20project%20%3D%20SERVER
247
https://jira.mongodb.org/browse/SERVER-10596
248
https://jira.mongodb.org/browse/SERVER-9907
249
https://jira.mongodb.org/browse/SERVER-11021
250
https://jira.mongodb.org/browse/SERVER-10554
251
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.7%22%20AND%20project%20%3D%20SERVER
252
https://jira.mongodb.org/browse/SERVER-10478
253
https://jira.mongodb.org/browse/SERVER-8891
254
https://jira.mongodb.org/browse/SERVER-10085
255
https://jira.mongodb.org/browse/SERVER-9832
256
https://jira.mongodb.org/browse/SERVER-9786
257
https://jira.mongodb.org/browse/SERVER-7080
258
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.6%22%20AND%20project%20%3D%20SERVER
259
https://jira.mongodb.org/browse/SERVER-9983
260
https://jira.mongodb.org/browse/SERVER-9878
261
https://jira.mongodb.org/browse/SERVER-9856
7.2. Previous Stable Releases 717
MongoDB Reference Manual, Release 2.6.4
Cong server performance improvements SERVER-9864
262
and SERVER-5442
263
.
Improved initial sync resilience to network failure SERVER-9853
264
.
All 2.4.5 improvements
265
.
2.4.4 June 4, 2013
Performance x for Windows version SERVER-9721
266
Fix for cong upgrade failure SERVER-9661
267
.
Migration to Cyrus SASL library for MongoDB Enterprise SERVER-8813
268
.
All 2.4.4 improvements
269
.
2.4.3 April 23, 2013
Fix for mongo shell ignoring modied objects _id eld SERVER-9385
270
.
Fix for race condition in log rotation SERVER-4739
271
.
Fix for copydb command with authorization in a sharded cluster SERVER-9093
272
.
All 2.4.3 improvements
273
.
2.4.2 April 17, 2013
Several V8 memory leak and performance xes SERVER-9267
274
and SERVER-9230
275
.
Fix for upgrading sharded clusters SERVER-9125
276
.
Fix for high volume connection crash SERVER-9014
277
.
All 2.4.2 improvements
278
2.4.1 April 17, 2013
Fix for losing index changes during initial sync SERVER-9087
279
262
https://jira.mongodb.org/browse/SERVER-9864
263
https://jira.mongodb.org/browse/SERVER-5442
264
https://jira.mongodb.org/browse/SERVER-9853
265
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.5%22%20AND%20project%20%3D%20SERVER
266
https://jira.mongodb.org/browse/SERVER-9721
267
https://jira.mongodb.org/browse/SERVER-9661
268
https://jira.mongodb.org/browse/SERVER-8813
269
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.4%22%20AND%20project%20%3D%20SERVER
270
https://jira.mongodb.org/browse/SERVER-9385
271
https://jira.mongodb.org/browse/SERVER-4739
272
https://jira.mongodb.org/browse/SERVER-9093
273
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.3%22%20AND%20project%20%3D%20SERVER
274
https://jira.mongodb.org/browse/SERVER-9267
275
https://jira.mongodb.org/browse/SERVER-9230
276
https://jira.mongodb.org/browse/SERVER-9125
277
https://jira.mongodb.org/browse/SERVER-9014
278
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.2%22%20AND%20project%20%3D%20SERVER
279
https://jira.mongodb.org/browse/SERVER-9087
718 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
All 2.4.1 improvements
280
.
Major New Features
The following changes in MongoDB affect both standard and Enterprise editions:
Text Search
Add support for text search of content in MongoDB databases as a beta feature. See
http://docs.mongodb.org/manualcore/index-text for more information.
Geospatial Support Enhancements
Add new 2dsphere index. The new index supports GeoJSON
281
objects Point,
LineString, and Polygon. See http://docs.mongodb.org/manualcore/2dsphere and
http://docs.mongodb.org/manualapplications/geospatial-indexes.
Introduce operators $geometry (page 414), $geoWithin (page 407) and $geoIntersects (page 406)
to work with the GeoJSON data.
Hashed Index
Add new hashed index to index documents using hashes of eld values. When used to index a shard key, the hashed
index ensures an evenly distributed shard key. See also sharding-hashed-sharding.
Improvements to the Aggregation Framework
Improve support for geospatial queries. See the $geoWithin (page 407) operator and the $geoNear
(page 458) pipeline stage.
Improve sort efciency when the $sort (page 473) stage immediately precedes a $limit (page 463) in the
pipeline.
Add new operators $millisecond (page 513) and $concat (page 499) and modify how $min (page 525)
operator processes null values.
Changes to Update Operators
Add new $setOnInsert (page 435) operator for use with upsert (page 70) .
Enhance functionality of the $push (page 444) operator, supporting its use with the $each (page 446), the
$sort (page 451), and the $slice (page 449) modiers.
Additional Limitations for Map-Reduce and $where Operations
The mapReduce (page 218) command, group (page 214) command, and the $where (page 404) operator expres-
sions cannot access certain global functions or properties, such as db, that are available in the mongo (page 580) shell.
See the individual command or operator for details.
280
https://jira.mongodb.org/issues/?jql=xVersion%20%3D%20%222.4.1%22%20AND%20project%20%3D%20SERVER
281
http://geojson.org/geojson-spec.html
7.2. Previous Stable Releases 719
MongoDB Reference Manual, Release 2.6.4
Improvements to serverStatus Command
Provide additional metrics and customization for the serverStatus (page 354) command. See
db.serverStatus() (page 125) and serverStatus (page 354) for more information.
Security Enhancements
Introduce a role-based access control system /reference/user-privileges
282
using new
http://docs.mongodb.org/manualreference/privilege-documents.
Enforce uniqueness of the user in user privilege documents per database. Previous versions of MongoDB did
not enforce this requirement, and existing databases may have duplicates.
Support encrypted connections using SSL certicates signed by a Certicate Authority. See
http://docs.mongodb.org/manualtutorial/configure-ssl.
For more information on security and risk management strategies, see MongoDB Security Practices and
Procedures.
Performance Improvements
V8 JavaScript Engine
JavaScript Changes in MongoDB 2.4 Consider the following impacts of V8 JavaScript Engine (page 720) in Mon-
goDB 2.4:
Tip
Use the new interpreterVersion() method in the mongo (page 580) shell and the javascriptEngine
(page 337) eld in the output of db.serverBuildInfo() (page 124) to determine which JavaScript engine a
MongoDB binary uses.
Improved Concurrency Previously, MongoDB operations that required the JavaScript interpreter had to acquire
a lock, and a single mongod (page 555) could only run a single JavaScript operation at a time. The switch to V8
improves concurrency by permitting multiple JavaScript operations to run at the same time.
Modernized JavaScript Implementation (ES5) The 5th edition of ECMAscript
283
, abbreviated as ES5, adds many
new language features, including:
standardized JSON
284
,
strict mode
285
,
function.bind()
286
,
array extensions
287
, and
getters and setters.
282
http://docs.mongodb.org/v2.4/reference/user-privileges
283
http://www.ecma-international.org/publications/standards/Ecma-262.htm
284
http://www.ecma-international.org/ecma-262/5.1/#sec-15.12.1
285
http://www.ecma-international.org/ecma-262/5.1/#sec-4.2.2
286
http://www.ecma-international.org/ecma-262/5.1/#sec-15.3.4.5
287
http://www.ecma-international.org/ecma-262/5.1/#sec-15.4.4.16
720 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
With V8, MongoDB supports the ES5 implementation of Javascript with the following exceptions.
Note: The following features do not work as expected on documents returned from MongoDB queries:
Object.seal() throws an exception on documents returned from MongoDB queries.
Object.freeze() throws an exception on documents returned from MongoDB queries.
Object.preventExtensions() incorrectly allows the addition of new properties on documents returned
from MongoDB queries.
enumerable properties, when added to documents returned from MongoDB queries, are not saved during
write operations.
See SERVER-8216
288
, SERVER-8223
289
, SERVER-8215
290
, and SERVER-8214
291
for more information.
For objects that have not been returned from MongoDB queries, the features work as expected.
Removed Non-Standard SpiderMonkey Features V8 does not support the following non-standard SpiderMon-
key
292
JavaScript extensions, previously supported by MongoDBs use of SpiderMonkey as its JavaScript engine.
E4X Extensions V8 does not support the non-standard E4X
293
extensions. E4X provides a native XML
294
object
to the JavaScript language and adds the syntax for embedding literal XML documents in JavaScript code.
You need to use alternative XML processing if you used any of the following constructors/methods:
XML()
Namespace()
QName()
XMLList()
isXMLName()
Destructuring Assignment V8 does not support the non-standard destructuring assignments. Destructuring assign-
ment extract[s] data from arrays or objects using a syntax that mirrors the construction of array and object literals. -
Mozilla docs
295
Example
The following destructuring assignment is invalid with V8 and throws a SyntaxError:
original = [4, 8, 15];
var [b, ,c] = a; // <== destructuring assignment
print(b) // 4
print(c) // 15
288
https://jira.mongodb.org/browse/SERVER-8216
289
https://jira.mongodb.org/browse/SERVER-8223
290
https://jira.mongodb.org/browse/SERVER-8215
291
https://jira.mongodb.org/browse/SERVER-8214
292
https://developer.mozilla.org/en-US/docs/SpiderMonkey
293
https://developer.mozilla.org/en-US/docs/E4X
294
https://developer.mozilla.org/en-US/docs/E4X/Processing_XML_with_E4X
295
https://developer.mozilla.org/en-US/docs/JavaScript/New_in_JavaScript/1.7#Destructuring_assignment_(Merge_into_own_page.2Fsection)
7.2. Previous Stable Releases 721
MongoDB Reference Manual, Release 2.6.4
Iterator(), StopIteration(), and Generators V8 does not support Iterator(), StopIteration(), and gener-
ators
296
.
InternalError() V8 does not support InternalError(). Use Error() instead.
for each...in Construct V8 does not support the use of for each...in
297
construct. Use for (var x in
y) construct instead.
Example
The following for each (var x in y) construct is invalid with V8:
var o = { name: 'MongoDB', version: 2.4 };
for each (var value in o) {
print(value);
}
Instead, in version 2.4, you can use the for (var x in y) construct:
var o = { name: 'MongoDB', version: 2.4 };
for (var prop in o) {
var value = o[prop];
print(value);
}
You can also use the array instance method forEach() with the ES5 method Object.keys():
Object.keys(o).forEach(function (key) {
var value = o[key];
print(value);
});
Array Comprehension V8 does not support Array comprehensions
298
.
Use other methods such as the Array instance methods map(), filter(), or forEach().
Example
With V8, the following array comprehension is invalid:
var a = { w: 1, x: 2, y: 3, z: 4 }
var arr = [i
*
i for each (i in a) if (i > 2)]
printjson(arr)
Instead, you can implement using the Array instance method forEach() and the ES5 method Object.keys()
:
var a = { w: 1, x: 2, y: 3, z: 4 }
var arr = [];
Object.keys(a).forEach(function (key) {
296
https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Iterators_and_Generators
297
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Statements/for_each...in
298
https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Predened_Core_Objects#Array_comprehensions
722 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
var val = a[key];
if (val > 2) arr.push(val
*
val);
})
printjson(arr)
Note: The new logic uses the Array instance method forEach() and not the generic method
Array.forEach(); V8 does not support Array generic methods. See Array Generic Methods (page 724) for
more information.
Multiple Catch Blocks V8 does not support multiple catch blocks and will throw a SyntaxError.
Example
The following multiple catch blocks is invalid with V8 and will throw "SyntaxError: Unexpected token
if":
try {
something()
} catch (err if err instanceof SomeError) {
print('some error')
} catch (err) {
print('standard error')
}
Conditional Function Denition V8 will produce different outcomes than SpiderMonkey with conditional function
denitions
299
.
Example
The following conditional function denition produces different outcomes in SpiderMonkey versus V8:
function test () {
if (false) {
function go () {};
}
print(typeof go)
}
With SpiderMonkey, the conditional function outputs undefined, whereas with V8, the conditional function outputs
function.
If your code denes functions this way, it is highly recommended that you refactor the code. The following example
refactors the conditional function denition to work in both SpiderMonkey and V8.
function test () {
var go;
if (false) {
go = function () {}
}
print(typeof go)
}
The refactored code outputs undefined in both SpiderMonkey and V8.
299
https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Functions
7.2. Previous Stable Releases 723
MongoDB Reference Manual, Release 2.6.4
Note: ECMAscript prohibits conditional function denitions. To force V8 to throw an Error, enable strict mode
300
.
function test () {
'use strict';
if (false) {
function go () {}
}
}
The JavaScript code throws the following syntax error:
SyntaxError: In strict mode code, functions can only be declared at top level or immediately within another function.
String Generic Methods V8 does not support String generics
301
. String generics are a set of methods on the
String class that mirror instance methods.
Example
The following use of the generic method String.toLowerCase() is invalid with V8:
var name = 'MongoDB';
var lower = String.toLowerCase(name);
With V8, use the String instance method toLowerCase() available through an instance of the String class
instead:
var name = 'MongoDB';
var lower = name.toLowerCase();
print(name + ' becomes ' + lower);
With V8, use the String instance methods instead of following generic methods:
String.charAt() String.quote() String.toLocaleLowerCase()
String.charCodeAt() String.replace() String.toLocaleUpperCase()
String.concat() String.search() String.toLowerCase()
String.endsWith() String.slice() String.toUpperCase()
String.indexOf() String.split() String.trim()
String.lastIndexOf() String.startsWith() String.trimLeft()
String.localeCompare() String.substr() String.trimRight()
String.match() String.substring()
Array Generic Methods V8 does not support Array generic methods
302
. Array generics are a set of methods on the
Array class that mirror instance methods.
Example
The following use of the generic method Array.every() is invalid with V8:
300
http://www.nczonline.net/blog/2012/03/13/its-time-to-start-using-javascript-strict-mode/
301
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/String#String_generic_methods
302
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array#Array_generic_methods
724 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
var arr = [4, 8, 15, 16, 23, 42];
function isEven (val) {
return 0 === val % 2;
}
var allEven = Array.every(arr, isEven);
print(allEven);
With V8, use the Array instance method every() available through an instance of the Array class instead:
var allEven = arr.every(isEven);
print(allEven);
With V8, use the Array instance methods instead of the following generic methods:
Array.concat() Array.lastIndexOf() Array.slice()
Array.every() Array.map() Array.some()
Array.filter() Array.pop() Array.sort()
Array.forEach() Array.push() Array.splice()
Array.indexOf() Array.reverse() Array.unshift()
Array.join() Array.shift()
Array Instance Method toSource() V8 does not support the Array instance method toSource()
303
. Use the
Array instance method toString() instead.
uneval() V8 does not support the non-standard method uneval(). Use the standardized JSON.stringify()
304
method instead.
Change default JavaScript engine from SpiderMonkey to V8. The change provides improved concurrency for
JavaScript operations, modernized JavaScript implementation, and the removal of non-standard SpiderMonkey fea-
tures, and affects all JavaScript behavior including the commands mapReduce (page 218), group (page 214), and
eval (page 235) and the query operator $where (page 404).
See JavaScript Changes in MongoDB 2.4 (page 720) for more information about all changes .
BSON Document Validation Enabled by Default for mongod and mongorestore
Enable basic BSON object validation for mongod (page 555) and mongorestore (page 597) when writing to
MongoDB data les. See wireObjectCheck for details.
Index Build Enhancements
Add support for multiple concurrent index builds in the background by a single mongod (page 555) instance.
See building indexes in the background for more information on background index builds.
Allow the db.killOp() (page 120) method to terminate a foreground index build.
Improve index validation during index creation. See Compatibility and Index Type Changes in MongoDB 2.4
(page 733) for more information.
303
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array/toSource
304
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/JSON/stringify
7.2. Previous Stable Releases 725
MongoDB Reference Manual, Release 2.6.4
Set Parameters as Command Line Options
Provide --setParameter as a command line option for mongos (page 571) and mongod (page 555). See
mongod (page 555) and mongos (page 571) for list of available options for setParameter.
Changed Replication Behavior for Chunk Migration
By default, each document move during chunk migration in a sharded cluster propagates to at least one secondary
before the balancer proceeds with its next operation. See chunk-migration-replication.
Improved Chunk Migration Queue Behavior
Increase performance for moving multiple chunks off an overloaded shard. The balancer no longer waits for the
current migrations delete phase to complete before starting the next chunk migration. See chunk-migration-queuing
for details.
Enterprise
The following changes are specic to MongoDB Enterprise Editions:
SASL Library Change
In 2.4.4, MongoDB Enterprise uses Cyrus SASL. Earlier 2.4 Enterprise versions use GNU SASL
(libgsasl). To upgrade to 2.4.4 MongoDB Enterprise or greater, you must install all pack-
age dependencies related to this change, including the appropriate Cyrus SASL GSSAPI library. See
http://docs.mongodb.org/manualtutorial/install-mongodb-enterprise for details of the
dependencies.
New Modular Authentication System with Support for Kerberos
In 2.4, the MongoDB Enterprise now supports authentication via a Kerberos mechanism. See
http://docs.mongodb.org/manualtutorial/control-access-to-mongodb-with-kerberos-authentication
for more information. For drivers that provide support for Kerberos authentication to MongoDB, refer to kerberos-
and-drivers.
For more information on security and risk management strategies, see MongoDB Security Practices and
Procedures.
Additional Information
Platform Notes
For OS X, MongoDB 2.4 only supports OS X versions 10.6 (Snow Leopard) and later. There are no other platform
support changes in MongoDB 2.4. See the downloads page
305
for more information on platform support.
305
http://www.mongodb.org/downloads/
726 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Upgrade Process
Upgrade MongoDB to 2.4 In the general case, the upgrade from MongoDB 2.2 to 2.4 is a binary-compatible drop-
in upgrade: shut down the mongod (page 555) instances and replace them with mongod (page 555) instances
running 2.4. However, before you attempt any upgrade please familiarize yourself with the content of this document,
particularly the procedure for upgrading sharded clusters (page 728) and the considerations for reverting to 2.2 after
running 2.4 (page 732).
Upgrade Recommendations and Checklist When upgrading, consider the following:
For all deployments using authentication, upgrade the drivers (i.e. client libraries), before upgrading the
mongod (page 555) instance or instances.
To upgrade to 2.4 sharded clusters must upgrade following the meta-data upgrade procedure (page 728).
If youre using 2.2.0 and running with authorization enabled, you will need to upgrade rst to 2.2.1
and then upgrade to 2.4. See Rolling Upgrade Limitation for 2.2.0 Deployments Running with auth Enabled
(page 732).
If you have system.users documents (i.e. for authorization) that you created before 2.4 you must
ensure that there are no duplicate values for the user eld in the system.users collection in any database.
If you do have documents with duplicate user elds, you must remove them before upgrading.
See Security Enhancements (page 720) for more information.
Upgrade Standalone mongod Instance to MongoDB 2.4
1. Download binaries of the latest release in the 2.4 series from the MongoDB Download Page
306
. See
http://docs.mongodb.org/manualinstallation for more information.
2. Shutdown your mongod (page 555) instance. Replace the existing binary with the 2.4 mongod (page 555)
binary and restart mongod (page 555).
Upgrade a Replica Set from MongoDB 2.2 to MongoDB 2.4 You can upgrade to 2.4 by performing a rolling up-
grade of the set by upgrading the members individually while the other members are available to minimize downtime.
Use the following procedure:
1. Upgrade the secondary members of the set one at a time by shutting down the mongod (page 555) and re-
placing the 2.2 binary with the 2.4 binary. After upgrading a mongod (page 555) instance, wait for the mem-
ber to recover to SECONDARY state before upgrading the next instance. To check the members state, issue
rs.status() (page 177) in the mongo (page 580) shell.
2. Use the mongo (page 580) shell method rs.stepDown() (page 177) to step down the primary to allow the
normal failover procedure. rs.stepDown() (page 177) expedites the failover procedure and is preferable to
shutting down the primary directly.
Once the primary has stepped down and another member has assumed PRIMARY state, as observed in the output
of rs.status() (page 177), shut down the previous primary and replace mongod (page 555) binary with
the 2.4 binary and start the new process.
Note: Replica set failover is not instant but will render the set unavailable to read or accept writes until the
failover process completes. Typically this takes 10 seconds or more. You may wish to plan the upgrade during
a predened maintenance window.
306
http://www.mongodb.org/downloads
7.2. Previous Stable Releases 727
MongoDB Reference Manual, Release 2.6.4
Upgrade a Sharded Cluster fromMongoDB2.2 to MongoDB2.4
Important: Only upgrade sharded clusters to 2.4 if all members of the cluster are currently running instances of 2.2.
The only supported upgrade path for sharded clusters running 2.0 is via 2.2.
Overview Upgrading a sharded cluster from MongoDB version 2.2 to 2.4 (or 2.3) requires that you run a 2.4
mongos (page 571) with the --upgrade option, described in this procedure. The upgrade process does not re-
quire downtime.
The upgrade to MongoDB 2.4 adds epochs to the meta-data for all collections and chunks in the existing cluster.
MongoDB 2.2 processes are capable of handling epochs, even though 2.2 did not require them. This procedure applies
only to upgrades from version 2.2. Earlier versions of MongoDB do not correctly handle epochs. See Cluster Meta-
data Upgrade (page 728) for more information.
After completing the meta-data upgrade you can fully upgrade the components of the cluster. With the balancer
disabled:
Upgrade all mongos (page 571) instances in the cluster.
Upgrade all 3 mongod (page 555) cong server instances.
Upgrade the mongod (page 555) instances for each shard, one at a time.
See Upgrade Sharded Cluster Components (page 731) for more information.
Cluster Meta-data Upgrade
Considerations Beware of the following properties of the cluster upgrade process:
Before you start the upgrade, ensure that the amount of free space on the lesystem for the cong database
(page 647) is at least 4 to 5 times the amount of space currently used by the cong database (page 647) data
les.
Additionally, ensure that all indexes in the cong database (page 647) are {v:1} indexes. If a critical index is
a {v:0} index, chunk splits can fail due to known issues with the {v:0} format. {v:0} indexes are present
on clusters created with MongoDB 2.0 or earlier.
The duration of the metadata upgrade depends on the network latency between the node performing the upgrade
and the three cong servers. Ensure low latency between the upgrade process and the cong servers.
While the upgrade is in progress, you cannot make changes to the collection meta-data. For example, during the
upgrade, do not perform:
sh.enableSharding() (page 185),
sh.shardCollection() (page 188),
sh.addShard() (page 182),
db.createCollection() (page 106),
db.collection.drop() (page 28),
db.dropDatabase() (page 113),
any operation that creates a database, or
any other operation that modies the cluster meta-data in any way. See
http://docs.mongodb.org/manualreference/sharding for a com-
plete list of sharding commands. Note, however, that not all commands on the
728 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
http://docs.mongodb.org/manualreference/sharding page modies the cluster
meta-data.
Once you upgrade to 2.4 and complete the upgrade procedure do not use 2.0 mongod (page 555) and mongos
(page 571) processes in your cluster. 2.0 process may re-introduce old meta-data formats into cluster meta-data.
The upgraded cong database will require more storage space than before, to make backup and working copies of the
config.chunks (page 649) and config.collections (page 649) collections. As always, if storage require-
ments increase, the mongod (page 555) might need to pre-allocate additional data les. See faq-tools-for-measuring-
storage-use for more information.
Meta-data Upgrade Procedure Changes to the meta-data format for sharded clusters, stored in the cong database
(page 647), require a special meta-data upgrade procedure when moving to 2.4.
Do not perform operations that modify meta-data while performing this procedure. See Upgrade a Sharded Cluster
from MongoDB 2.2 to MongoDB 2.4 (page 728) for examples of prohibited operations.
1. Before you start the upgrade, ensure that the amount of free space on the lesystem for the cong database
(page 647) is at least 4 to 5 times the amount of space currently used by the cong database (page 647) data
les.
Additionally, ensure that all indexes in the cong database (page 647) are {v:1} indexes. If a critical index is
a {v:0} index, chunk splits can fail due to known issues with the {v:0} format. {v:0} indexes are present
on clusters created with MongoDB 2.0 or earlier.
The duration of the metadata upgrade depends on the network latency between the node performing the upgrade
and the three cong servers. Ensure low latency between the upgrade process and the cong servers.
To check the version of your indexes, use db.collection.getIndexes() (page 45).
If any index on the cong database is {v:0}, you should rebuild those indexes by connecting to the
mongos (page 571) and either: rebuild all indexes using the db.collection.reIndex() (page 63)
method, or drop and rebuild specic indexes using db.collection.dropIndex() (page 29) and then
db.collection.ensureIndex() (page 30). If you need to upgrade the _id index to {v:1} use
db.collection.reIndex() (page 63).
You may have {v:0} indexes on other databases in the cluster.
2. Turn off the balancer in the sharded cluster, as described in sharding-balancing-disable-temporarily.
Optional
For additional security during the upgrade, you can make a backup of the cong database using mongodump
(page 590) or other backup tools.
3. Ensure there are no version 2.0 mongod (page 555) or mongos (page 571) processes still active in the sharded
cluster. The automated upgrade process checks for 2.0 processes, but network availability can prevent a deni-
tive check. Wait 5 minutes after stopping or upgrading version 2.0 mongos (page 571) processes to conrm
that none are still active.
4. Start a single 2.4 mongos (page 571) process with configDB pointing to the sharded clusters cong servers
and with the --upgrade option. The upgrade process happens before the process becomes a daemon (i.e.
before --fork.)
You can upgrade an existing mongos (page 571) instance to 2.4 or you can start a new mongos instance that
can reach all cong servers if you need to avoid reconguring a production mongos (page 571).
Start the mongos (page 571) with a command that resembles the following:
7.2. Previous Stable Releases 729
MongoDB Reference Manual, Release 2.6.4
mongos --configdb <config servers> --upgrade
Without the --upgrade option 2.4 mongos (page 571) processes will fail to start until the upgrade process is
complete.
The upgrade will prevent any chunk moves or splits from occurring during the upgrade process. If there are
very many sharded collections or there are stale locks held by other failed processes, acquiring the locks for all
collections can take seconds or minutes. See the log for progress updates.
5. When the mongos (page 571) process starts successfully, the upgrade is complete. If the mongos (page 571)
process fails to start, check the log for more information.
If the mongos (page 571) terminates or loses its connection to the cong servers during the upgrade, you may
always safely retry the upgrade.
However, if the upgrade failed during the short critical section, the mongos (page 571) will exit and report that
the upgrade will require manual intervention. To continue the upgrade process, you must follow the Resync
after an Interruption of the Critical Section (page 730) procedure.
Optional
If the mongos (page 571) logs show the upgrade waiting for the upgrade lock, a previous upgrade process may
still be active or may have ended abnormally. After 15 minutes of no remote activity mongos (page 571) will
force the upgrade lock. If you can verify that there are no running upgrade processes, you may connect to a 2.2
mongos (page 571) process and force the lock manually:
mongo <mongos.example.net>
db.getMongo().getCollection("config.locks").findOne({ _id : "configUpgrade" })
If the process specied in the process eld of this document is veriably ofine, run the following operation
to force the lock.
db.getMongo().getCollection("config.locks").update({ _id : "configUpgrade" }, { $set : { state : 0 } })
It is always more safe to wait for the mongos (page 571) to verify that the lock is inactive, if you have any
doubts about the activity of another upgrade operation. In addition to the configUpgrade, the mongos
(page 571) may need to wait for specic collection locks. Do not force the specic collection locks.
6. Upgrade and restart other mongos (page 571) processes in the sharded cluster, without the --upgrade option.
See Upgrade Sharded Cluster Components (page 731) for more information.
7. Re-enable the balancer. You can now perform operations that modify cluster meta-data.
Once you have upgraded, do not introduce version 2.0 MongoDB processes into the sharded cluster. This can rein-
troduce old meta-data formats into the cong servers. The meta-data change made by this upgrade process will help
prevent errors caused by cross-version incompatibilities in future versions of MongoDB.
Resync after an Interruption of the Critical Section During the short critical section of the upgrade that applies
changes to the meta-data, it is unlikely but possible that a network interruption can prevent all three cong servers
from verifying or modifying data. If this occurs, the cong servers must be re-synced, and there may be problems
starting new mongos (page 571) processes. The sharded cluster will remain accessible, but avoid all cluster meta-
data changes until you resync the cong servers. Operations that change meta-data include: adding shards, dropping
databases, and dropping collections.
Note: Only perform the following procedure if something (e.g. network, power, etc.) interrupts the upgrade process
during the short critical section of the upgrade. Remember, you may always safely attempt the meta data upgrade
procedure (page 729).
730 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
To resync the cong servers:
1. Turn off the balancer in the sharded cluster and stop all meta-data operations. If you are in the middle of an
upgrade process (Upgrade a Sharded Cluster from MongoDB 2.2 to MongoDB 2.4 (page 728)), you have already
disabled the balancer.
2. Shut down two of the three cong servers, preferably the last two listed in the configDB string. For example, if
your configDB string is configA:27019,configB:27019,configC:27019, shut down configB
and configC. Shutting down the last two cong servers ensures that most mongos (page 571) instances will
have uninterrupted access to cluster meta-data.
3. mongodump (page 590) the data les of the active cong server (configA).
4. Move the data les of the deactivated cong servers (configB and configC) to a backup location.
5. Create new, empty data directories.
6. Restart the disabled cong servers with --dbpath pointing to the now-empty data directory and --port
pointing to an alternate port (e.g. 27020).
7. Use mongorestore (page 597) to repopulate the data les on the disabled documents from the active cong
server (configA) to the restarted cong servers on the new port (configB:27020,configC:27020).
These cong servers are now re-synced.
8. Restart the restored cong servers on the old port, resetting the port back to the old settings (configB:27019
and configC:27019).
9. In some cases connection pooling may cause spurious failures, as the mongos (page 571) disables old con-
nections only after attempted use. 2.4 xes this problem, but to avoid this issue in version 2.2, you can restart
all mongos (page 571) instances (one-by-one, to avoid downtime) and use the rs.stepDown() (page 177)
method before restarting each of the shard replica set primaries.
10. The sharded cluster is now fully resynced; however before you attempt the upgrade process again, you must
manually reset the upgrade state using a version 2.2 mongos (page 571). Begin by connecting to the 2.2
mongos (page 571) with the mongo (page 580) shell:
mongo <mongos.example.net>
Then, use the following operation to reset the upgrade process:
db.getMongo().getCollection("config.version").update({ _id : 1 }, { $unset : { upgradeState : 1 } })
11. Finally retry the upgrade process, as in Upgrade a Sharded Cluster from MongoDB 2.2 to MongoDB 2.4
(page 728).
Upgrade Sharded Cluster Components After you have successfully completed the meta-data upgrade process
described in Meta-data Upgrade Procedure (page 729), and the 2.4 mongos (page 571) instance starts, you can
upgrade the other processes in your MongoDB deployment.
While the balancer is still disabled, upgrade the components of your sharded cluster in the following order:
Upgrade all mongos (page 571) instances in the cluster, in any order.
Upgrade all 3 mongod (page 555) cong server instances, upgrading the rst system in the mongos
--configdb argument last.
Upgrade each shard, one at a time, upgrading the mongod (page 555) secondaries before running
replSetStepDown (page 294) and upgrading the primary of each shard.
When this process is complete, you can now re-enable the balancer.
7.2. Previous Stable Releases 731
MongoDB Reference Manual, Release 2.6.4
Rolling Upgrade Limitation for 2.2.0 Deployments Running with auth Enabled MongoDB cannot support
deployments that mix 2.2.0 and 2.4.0, or greater, components. MongoDB version 2.2.1 and later processes can exist in
mixed deployments with 2.4-series processes. Therefore you cannot perform a rolling upgrade from MongoDB 2.2.0
to MongoDB 2.4.0. To upgrade a cluster with 2.2.0 components, use one of the following procedures.
1. Perform a rolling upgrade of all 2.2.0 processes to the latest 2.2-series release (e.g. 2.2.3) so that there are no
processes in the deployment that predate 2.2.1. When there are no 2.2.0 processes in the deployment, perform a
rolling upgrade to 2.4.0.
2. Stop all processes in the cluster. Upgrade all processes to a 2.4-series release of MongoDB, and start all pro-
cesses at the same time.
Upgrade from 2.3 to 2.4 If you used a mongod (page 555) from the 2.3 or 2.4-rc (release candidate) series, you
can safely transition these databases to 2.4.0 or later; however, if you created 2dsphere or text indexes using a
mongod (page 555) before v2.4-rc2, you will need to rebuild these indexes. For example:
db.records.dropIndex( { loc: "2dsphere" } )
db.records.dropIndex( "records_text" )
db.records.ensureIndex( { loc: "2dsphere" } )
db.records.ensureIndex( { records: "text" } )
Downgrade MongoDB from 2.4 to Previous Versions For some cases the on-disk format of data les used by 2.4
and 2.2 mongod (page 555) is compatible, and you can upgrade and downgrade if needed. However, several new
features in 2.4 are incompatible with previous versions:
2dsphere indexes are incompatible with 2.2 and earlier mongod (page 555) instances.
text indexes are incompatible with 2.2 and earlier mongod (page 555) instances.
using a hashed index as a shard key are incompatible with 2.2 and earlier mongos (page 571) instances.
hashed indexes are incompatible with 2.0 and earlier mongod (page 555) instances.
Important: Collections sharded using hashed shard keys, should not use 2.2 mongod (page 555) instances, which
cannot correctly support cluster operations for these collections.
If you completed the meta-data upgrade for a sharded cluster (page 728), you can safely downgrade to 2.2 MongoDB
processes. Do not use 2.0 processes after completing the upgrade procedure.
Note: In sharded clusters, once you have completed the meta-data upgrade procedure (page 728), you cannot use 2.0
mongod (page 555) or mongos (page 571) instances in the same cluster.
If you complete the meta-data upgrade, you can safely downgrade components in any order. When upgrade again,
always upgrade mongos (page 571) instances before mongod (page 555) instances.
Do not create 2dsphere or text indexes in a cluster that has 2.2 components.
Considerations and Compatibility If you upgrade to MongoDB 2.4, and then need to run MongoDB 2.2 with the
same data les, consider the following limitations.
If you use a hashed index as the shard key index, which is only possible under 2.4 you will not be able to
query data in this sharded collection. Furthermore, a 2.2 mongos (page 571) cannot properly route an insert
operation for a collections sharded using a hashed index for the shard key index: any data that you insert using
a 2.2 mongos (page 571), will not arrive on the correct shard and will not be reachable by future queries.
732 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
If you never create an 2dsphere or text index, you can move between a 2.4 and 2.2 mongod (page 555) for
a given data set; however, after you create the rst 2dsphere or text index with a 2.4 mongod (page 555)
you will need to run a 2.2 mongod (page 555) with the --upgrade option and drop any 2dsphere or text
index.
Upgrade and Downgrade Procedures
Basic Downgrade and Upgrade Except as described below, moving between 2.2 and 2.4 is a drop-in replacement:
stop the existing mongod (page 555), using the --shutdown option as follows:
mongod --dbpath /var/mongod/data --shutdown
Replace /var/mongod/data with your MongoDB dbPath.
start the new mongod (page 555) processes with the same dbPath setting, for example:
mongod --dbpath /var/mongod/data
Replace /var/mongod/data with your MongoDB dbPath.
Downgrade to 2.2 After Creating a 2dsphere or text Index If you have created 2dsphere or text indexes
while running a 2.4 mongod (page 555) instance, you can downgrade at any time, by starting the 2.2 mongod
(page 555) with the --upgrade option as follows:
mongod --dbpath /var/mongod/data/ --upgrade
Then, you will need to drop any existing 2dsphere or text indexes using db.collection.dropIndex()
(page 29), for example:
db.records.dropIndex( { loc: "2dsphere" } )
db.records.dropIndex( "records_text" )
Warning: --upgrade will run repairDatabase (page 332) on any database where you have created a
2dsphere or text index, which will rebuild all indexes.
Troubleshooting Upgrade/Downgrade Operations If you do not use --upgrade, when you attempt to start a 2.2
mongod (page 555) and you have created a 2dsphere or text index, mongod (page 555) will return the following
message:
'need to upgrade database index_plugin_upgrade with pdfile version 4.6, new version: 4.5 Not upgrading, exiting'
While running 2.4, to check the data le version of a MongoDB database, use the following operation in the shell:
db.getSiblingDB('<databasename>').stats().dataFileVersion
The major data le
307
version for both 2.2 and 2.4 is 4, the minor data le version for 2.2 is 5 and the minor data le
version for 2.4 is 6 after you create a 2dsphere or text index.
Compatibility and Index Type Changes in MongoDB 2.4 In 2.4 MongoDB includes two new features related to
indexes that users upgrading to version 2.4 must consider, particularly with regard to possible downgrade paths. For
more information on downgrades, see Downgrade MongoDB from 2.4 to Previous Versions (page 732).
307
The data le version (i.e. pdfile version) is independent and unrelated to the release version of MongoDB.
7.2. Previous Stable Releases 733
MongoDB Reference Manual, Release 2.6.4
New Index Types In 2.4 MongoDB adds two new index types: 2dsphere and text. These index types do not
exist in 2.2, and for each database, creating a 2dsphere or text index, will upgrade the data-le version and make
that database incompatible with 2.2.
If you intend to downgrade, you should always drop all 2dsphere and text indexes before moving to 2.2.
You can use the downgrade procedure (page 732) to downgrade these databases and run 2.2 if needed, however this
will run a full database repair (as with repairDatabase (page 332)) for all affected databases.
Index Type Validation In MongoDB 2.2 and earlier you could specify invalid index types that did not exist. In
these situations, MongoDB would create an ascending (e.g. 1) index. Invalid indexes include index types specied by
strings that do not refer to an existing index type, and all numbers other than 1 and -1.
308
In 2.4, creating any invalid index will result in an error. Furthermore, you cannot create a 2dsphere or text index
on a collection if its containing database has any invalid index types.
1
Example
If you attempt to add an invalid index in MongoDB 2.4, as in the following:
db.coll.ensureIndex( { field: "1" } )
MongoDB will return the following error document:
{
"err" : "Unknown index plugin '1' in index { field: \"1\" }"
"code": 16734,
"n": <number>,
"connectionId": <number>,
"ok": 1
}
See Upgrade MongoDB to 2.4 (page 727) for full upgrade instructions.
Other Resources
MongoDB Downloads
309
.
All JIRA issues resolved in 2.4
310
.
All Backwards incompatible changes
311
.
All Third Party License Notices
312
.
7.2.2 Release Notes for MongoDB 2.2
Upgrading
MongoDB 2.2 is a production release series and succeeds the 2.0 production release series.
308
In 2.4, indexes that specify a type of "1" or "-1" (the strings "1" and "-1") will continue to exist, despite a warning on start-up. However,
a secondary in a replica set cannot complete an initial sync from a primary that has a "1" or "-1" index. Avoid all indexes with invalid types.
309
http://mongodb.org/downloads
310
https://jira.mongodb.org/secure/IssueNavigator.jspa?reset=true&jqlQuery=project+%3D+SERVER+AND+xVersion+in+%28%222.3.2%22,+%222.3.1%22,+%222.3.0%22,+%222.4.0-
rc0%22,+%222.4.0-rc1%22,+%222.4.0-rc2%22,+%222.4.0-rc3%22%29
311
https://jira.mongodb.org/issues/?jql=project%20%3D%20SERVER%20AND%20xVersion%20in%20(%222.3.2%22%2C%20%222.3.1%22%2C%20%222.3.0%22%2C%20%222.4.0-
rc0%22%2C%20%222.4.0-rc1%22%2C%20%222.4.0-rc2%22%2C%20%222.4.0-rc3%22)%20AND%20%22Backwards%20Compatibility%22%20in%20(%22Major%20Change%22%2C%22Minor%20Change%22%20)%20ORDER%20BY%20votes%20DESC%2C%20issuetype%20DESC%2C%20key%20DESC
312
https://github.com/mongodb/mongo/blob/v2.4/distsrc/THIRD-PARTY-NOTICES
734 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
MongoDB 2.0 data les are compatible with 2.2-series binaries without any special migration process. However,
always perform the upgrade process for replica sets and sharded clusters using the procedures that follow.
Synopsis
mongod (page 555), 2.2 is a drop-in replacement for 2.0 and 1.8.
Check your driver documentation for information regarding required compatibility upgrades, and always run
the recent release of your driver.
Typically, only users running with authentication, will need to upgrade drivers before continuing with the up-
grade to 2.2.
For all deployments using authentication, upgrade the drivers (i.e. client libraries), before upgrading the
mongod (page 555) instance or instances.
For all upgrades of sharded clusters:
turn off the balancer during the upgrade process. See the sharding-balancing-disable-temporarily section
for more information.
upgrade all mongos (page 571) instances before upgrading any mongod (page 555) instances.
Other than the above restrictions, 2.2 processes can interoperate with 2.0 and 1.8 tools and processes. You can safely
upgrade the mongod (page 555) and mongos (page 571) components of a deployment one by one while the deploy-
ment is otherwise operational. Be sure to read the detailed upgrade procedures below before upgrading production
systems.
Upgrading a Standalone mongod
1. Download binaries of the latest release in the 2.2 series from the MongoDB Download Page
313
.
2. Shutdown your mongod (page 555) instance. Replace the existing binary with the 2.2 mongod (page 555)
binary and restart MongoDB.
Upgrading a Replica Set
You can upgrade to 2.2 by performing a rolling upgrade of the set by upgrading the members individually while the
other members are available to minimize downtime. Use the following procedure:
1. Upgrade the secondary members of the set one at a time by shutting down the mongod (page 555) and re-
placing the 2.0 binary with the 2.2 binary. After upgrading a mongod (page 555) instance, wait for the mem-
ber to recover to SECONDARY state before upgrading the next instance. To check the members state, issue
rs.status() (page 177) in the mongo (page 580) shell.
2. Use the mongo (page 580) shell method rs.stepDown() (page 177) to step down the primary to allow the
normal failover procedure. rs.stepDown() (page 177) expedites the failover procedure and is preferable to
shutting down the primary directly.
Once the primary has stepped down and another member has assumed PRIMARY state, as observed in the output
of rs.status() (page 177), shut down the previous primary and replace mongod (page 555) binary with
the 2.2 binary and start the new process.
Note: Replica set failover is not instant but will render the set unavailable to read or accept writes until the
313
http://downloads.mongodb.org/
7.2. Previous Stable Releases 735
MongoDB Reference Manual, Release 2.6.4
failover process completes. Typically this takes 10 seconds or more. You may wish to plan the upgrade during
a predened maintenance window.
Upgrading a Sharded Cluster
Use the following procedure to upgrade a sharded cluster:
Disable the balancer.
Upgrade all mongos (page 571) instances rst, in any order.
Upgrade all of the mongod (page 555) cong server instances using the stand alone (page 735) procedure. To
keep the cluster online, be sure that at all times at least one cong server is up.
Upgrade each shards replica set, using the upgrade procedure for replica sets (page 735) detailed above.
re-enable the balancer.
Note: Balancing is not currently supported in mixed 2.0.x and 2.2.0 deployments. Thus you will want to reach a
consistent version for all shards within a reasonable period of time, e.g. same-day. See SERVER-6902
314
for more
information.
Changes
Major Features
Aggregation Framework The aggregation framework makes it possible to do aggregation operations without
needing to use map-reduce. The aggregate (page 208) command exposes the aggregation framework, and the
aggregate() (page 22) helper in the mongo (page 580) shell provides an interface to these operations. Consider
the following resources for background on the aggregation framework and its use:
Documentation: http://docs.mongodb.org/manualcore/aggregation
Reference: Aggregation Reference (page 536)
Examples: http://docs.mongodb.org/manualapplications/aggregation
TTL Collections TTL collections remove expired data from a collection, using a special index and a background
thread that deletes expired documents every minute. These collections are useful as an alternative to capped collections
in some cases, such as for data warehousing and caching cases, including: machine generated event data, logs, and
session information that needs to persist in a database for only a limited period of time.
For more information, see the http://docs.mongodb.org/manualtutorial/expire-data tutorial.
Concurrency Improvements MongoDB 2.2 increases the servers capacity for concurrent operations with the fol-
lowing improvements:
1. DB Level Locking
315
2. Improved Yielding on Page Faults
316
3. Improved Page Fault Detection on Windows
317
314
https://jira.mongodb.org/browse/SERVER-6902
315
https://jira.mongodb.org/browse/SERVER-4328
316
https://jira.mongodb.org/browse/SERVER-3357
317
https://jira.mongodb.org/browse/SERVER-4538
736 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
To reect these changes, MongoDB now provides changed and improved reporting for concurrency and use, see locks
(page 355) and recordStats (page 366) in server status (page 354) and see db.currentOp() (page 107), mongotop
(page 630), and mongostat (page 623).
Improved Data Center Awareness with Tag Aware Sharding MongoDB 2.2 adds additional support for geo-
graphic distribution or other custom partitioning for sharded collections in clusters. By using this tag aware shard-
ing, you can automatically ensure that data in a sharded database system is always on specic shards. For example,
with tag aware sharding, you can ensure that data is closest to the application servers that use that data most frequently.
Shard tagging controls data location, and is complementary but separate from replica set tagging, which controls read
preference and write concern. For example, shard tagging can pin all USA data to one or more logical shards,
while replica set tagging can control which mongod (page 555) instances (e.g. production or reporting)
the application uses to service requests.
See the documentation for the following helpers in the mongo (page 580) shell that support tagged sharding congu-
ration:
sh.addShardTag() (page 183)
sh.addTagRange() (page 183)
sh.removeShardTag() (page 187)
Also, see http://docs.mongodb.org/manualcore/tag-aware-sharding and
http://docs.mongodb.org/manualtutorial/administer-shard-tags.
Fully Supported Read Preference Semantics All MongoDB clients and drivers now support full read
preferences, including consistent support for a full range of read preference modes and tag sets. This support
extends to the mongos (page 571) and applies identically to single replica sets and to the replica sets for each shard
in a sharded cluster.
Additional read preference support now exists in the mongo (page 580) shell using the readPref() (page 94)
cursor method.
Compatibility Changes
Authentication Changes MongoDB 2.2 provides more reliable and robust support for authentication clients, in-
cluding drivers and mongos (page 571) instances.
If your cluster runs with authentication:
For all drivers, use the latest release of your driver and check its release notes.
In sharded environments, to ensure that your cluster remains available during the upgrade process you must use
the upgrade procedure for sharded clusters (page 736).
findAndModify Returns Null Value for Upserts that Perform Inserts In version 2.2, for upsert that perform
inserts with the new option set to false, findAndModify (page 237) commands will now return the following
output:
{ 'ok': 1.0, 'value': null }
In the mongo (page 580) shell, upsert findAndModify (page 237) operations that perform inserts (with new set to
false.)only output a null value.
In version 2.0 these operations would return an empty document, e.g. { }.
7.2. Previous Stable Releases 737
MongoDB Reference Manual, Release 2.6.4
See: SERVER-6226
318
for more information.
mongodump 2.2 Output Incompatible with Pre-2.2 mongorestore If you use the mongodump (page 590)
tool from the 2.2 distribution to create a dump of a database, you must use a 2.2 (or later) version of mongorestore
(page 597) to restore that dump.
See: SERVER-6961
319
for more information.
ObjectId().toString() Returns String Literal ObjectId("...") In version 2.2, the toString()
(page 197) method returns the string representation of the ObjectId() object and has the format ObjectId("...").
Consider the following example that calls the toString() (page 197) method on the
ObjectId("507c7f79bcf86cd7994f6c0e") object:
ObjectId("507c7f79bcf86cd7994f6c0e").toString()
The method now returns the string ObjectId("507c7f79bcf86cd7994f6c0e").
Previously, in version 2.0, the method would return the hexadecimal string 507c7f79bcf86cd7994f6c0e.
If compatibility between versions 2.0 and 2.2 is required, use ObjectId().str, which holds the hexadecimal string value
in both versions.
ObjectId().valueOf() Returns hexadecimal string In version 2.2, the valueOf() (page 198) method
returns the value of the ObjectId() object as a lowercase hexadecimal string.
Consider the following example that calls the valueOf() (page 198) method on the
ObjectId("507c7f79bcf86cd7994f6c0e") object:
ObjectId("507c7f79bcf86cd7994f6c0e").valueOf()
The method now returns the hexadecimal string 507c7f79bcf86cd7994f6c0e.
Previously, in version 2.0, the method would return the object ObjectId("507c7f79bcf86cd7994f6c0e").
If compatibility between versions 2.0 and 2.2 is required, use ObjectId().str attribute, which holds the hexadecimal
string value in both versions.
Behavioral Changes
Restrictions on Collection Names In version 2.2, collection names cannot:
contain the $.
be an empty string (i.e. "").
This change does not affect collections created with now illegal names in earlier versions of MongoDB.
These new restrictions are in addition to the existing restrictions on collection names which are:
A collection name should begin with a letter or an underscore.
A collection name cannot contain the null character.
Begin with the system. prex. MongoDB reserves system. for system collections, such as the
system.indexes collection.
318
https://jira.mongodb.org/browse/SERVER-6226
319
https://jira.mongodb.org/browse/SERVER-6961
738 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
The maximum size of a collection name is 128 characters, including the name of the database. However, for
maximum exibility, collections should have names less than 80 characters.
Collections names may have any other valid UTF-8 string.
See the SERVER-4442
320
and the faq-restrictions-on-collection-names FAQ item.
Restrictions on Database Names for Windows Database names running on Windows can no longer contain the
following characters:
/\. "
*
<>:|?
The names of the data les include the database name. If you attempt to upgrade a database instance with one or more
of these characters, mongod (page 555) will refuse to start.
Change the name of these databases before upgrading. See SERVER-4584
321
and SERVER-6729
322
for more infor-
mation.
_id Fields and Indexes on Capped Collections All capped collections now have an _id eld by default, if they
exist outside of the local database, and now have indexes on the _id eld. This change only affects capped
collections created with 2.2 instances and does not affect existing capped collections.
See: SERVER-5516
323
for more information.
New$elemMatch Projection Operator The $elemMatch (page 425) operator allows applications to narrow the
data returned from queries so that the query operation will only return the rst matching element in an array. See the
$elemMatch (projection) (page 425) documentation and the SERVER-2238
324
and SERVER-828
325
issues for more
information.
Windows Specic Changes
Windows XP is Not Supported As of 2.2, MongoDB does not support Windows XP. Please upgrade to a more
recent version of Windows to use the latest releases of MongoDB. See SERVER-5648
326
for more information.
Service Support for mongos.exe You may now run mongos.exe (page 588) instances as a Windows Service.
See the mongos.exe (page 588) reference and tutorial-mongod-as-windows-service and SERVER-1589
327
for more
information.
Log Rotate Command Support MongoDB for Windows now supports log rotation by way of the logRotate
(page 330) database command. See SERVER-2612
328
for more information.
320
https://jira.mongodb.org/browse/SERVER-4442
321
https://jira.mongodb.org/browse/SERVER-4584
322
https://jira.mongodb.org/browse/SERVER-6729
323
https://jira.mongodb.org/browse/SERVER-5516
324
https://jira.mongodb.org/browse/SERVER-2238
325
https://jira.mongodb.org/browse/SERVER-828
326
https://jira.mongodb.org/browse/SERVER-5648
327
https://jira.mongodb.org/browse/SERVER-1589
328
https://jira.mongodb.org/browse/SERVER-2612
7.2. Previous Stable Releases 739
MongoDB Reference Manual, Release 2.6.4
New Build Using SlimReadWrite Locks for Windows Concurrency Labeled 2008+ on the Downloads Page
329
,
this build for 64-bit versions of Windows Server 2008 R2 and for Windows 7 or newer, offers increased performance
over the standard 64-bit Windows build of MongoDB. See SERVER-3844
330
for more information.
Tool Improvements
Index Denitions Handled by mongodump and mongorestore When you specify the --collection option
to mongodump (page 590), mongodump (page 590) will now backup the denitions for all indexes that exist on the
source database. When you attempt to restore this backup with mongorestore (page 597), the target mongod
(page 555) will rebuild all indexes. See SERVER-808
331
for more information.
mongorestore (page 597) now includes the --noIndexRestore option to provide the preceding behavior. Use
--noIndexRestore to prevent mongorestore (page 597) from building previous indexes.
mongooplog for Replaying Oplogs The mongooplog (page 604) tool makes it possible to pull oplog en-
tries from mongod (page 555) instance and apply them to another mongod (page 555) instance. You can use
mongooplog (page 604) to achieve point-in-time backup of a MongoDB data set. See the SERVER-3873
332
case
and the mongooplog (page 604) documentation.
Authentication Support for mongotop and mongostat mongotop (page 630) and mongostat (page 624)
now contain support for username/password authentication. See SERVER-3875
333
and SERVER-3871
334
for more in-
formation regarding this change. Also consider the documentation of the following options for additional information:
mongotop --username
mongotop --password
mongostat --username
mongostat --password
Write Concern Support for mongoimport and mongorestore mongoimport (page 610) now provides an
option to halt the import if the operation encounters an error, such as a network interruption, a duplicate key exception,
or a write error. The --stopOnError option will produce an error rather than silently continue importing data. See
SERVER-3937
335
for more information.
In mongorestore (page 597), the --w option provides support for congurable write concern.
mongodump Support for Reading from Secondaries You can now run mongodump (page 590) when connected
to a secondary member of a replica set. See SERVER-3854
336
for more information.
mongoimport Support for full 16MB Documents Previously, mongoimport (page 610) would only import
documents that were less than 4 megabytes in size. This issue is now corrected, and you may use mongoimport
(page 610) to import documents that are at least 16 megabytes ins size. See SERVER-4593
337
for more information.
329
http://www.mongodb.org/downloads
330
https://jira.mongodb.org/browse/SERVER-3844
331
https://jira.mongodb.org/browse/SERVER-808
332
https://jira.mongodb.org/browse/SERVER-3873
333
https://jira.mongodb.org/browse/SERVER-3875
334
https://jira.mongodb.org/browse/SERVER-3871
335
https://jira.mongodb.org/browse/SERVER-3937
336
https://jira.mongodb.org/browse/SERVER-3854
337
https://jira.mongodb.org/browse/SERVER-4593
740 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Timestamp() Extended JSON format MongoDB extended JSON now includes a new Timestamp() type to
represent the Timestamp type that MongoDB uses for timestamps in the oplog among other contexts.
This permits tools like mongooplog (page 604) and mongodump (page 590) to query for specic timestamps.
Consider the following mongodump (page 590) operation:
mongodump --db local --collection oplog.rs --query '{"ts":{"$gt":{"$timestamp" : {"t": 1344969612000, "i": 1 }}}}' --out oplog-dump
See SERVER-3483
338
for more information.
Shell Improvements
Improved Shell User Interface 2.2 includes a number of changes that improve the overall quality and consistency
of the user interface for the mongo (page 580) shell:
Full Unicode support.
Bash-like line editing features. See SERVER-4312
339
for more information.
Multi-line command support in shell history. See SERVER-3470
340
for more information.
Windows support for the edit command. See SERVER-3998
341
for more information.
Helper to load Server-Side Functions The db.loadServerScripts() (page 120) loads the contents of the
current databases system.js collection into the current mongo (page 580) shell session. See SERVER-1651
342
for
more information.
Support for Bulk Inserts If you pass an array of documents to the insert() (page 53) method, the mongo
(page 580) shell will now perform a bulk insert operation. See SERVER-3819
343
and SERVER-2395
344
for more
information.
Note: For bulk inserts on sharded clusters, the getLastError (page 243) command alone is insufcient to verify
success. Applications should must verify the success of bulk inserts in application logic.
Operations
Support for Logging to Syslog See the SERVER-2957
345
case and the documentation of the syslogFacility
run-time option or the mongod --syslog and mongos --syslog command line-options.
touch Command Added the touch (page 335) command to read the data and/or indexes from a collection into
memory. See: SERVER-2023
346
and touch (page 335) for more information.
indexCounters No Longer Report Sampled Data indexCounters now report actual counters that reect
index use and state. In previous versions, these data were sampled. See SERVER-5784
347
and indexCounters for
338
https://jira.mongodb.org/browse/SERVER-3483
339
https://jira.mongodb.org/browse/SERVER-4312
340
https://jira.mongodb.org/browse/SERVER-3470
341
https://jira.mongodb.org/browse/SERVER-3998
342
https://jira.mongodb.org/browse/SERVER-1651
343
https://jira.mongodb.org/browse/SERVER-3819
344
https://jira.mongodb.org/browse/SERVER-2395
345
https://jira.mongodb.org/browse/SERVER-2957
346
https://jira.mongodb.org/browse/SERVER-2023
347
https://jira.mongodb.org/browse/SERVER-5784
7.2. Previous Stable Releases 741
MongoDB Reference Manual, Release 2.6.4
more information.
Padding Speciable on compact Command See the documentation of the compact (page 316) and the
SERVER-4018
348
issue for more information.
Added Build Flag to Use System Libraries The Boost library, version 1.49, is now embedded in the MongoDB
code base.
If you want to build MongoDB binaries using system Boost libraries, you can pass scons using the
--use-system-boost ag, as follows:
scons --use-system-boost
When building MongoDB, you can also pass scons a ag to compile MongoDB using only system libraries rather
than the included versions of the libraries. For example:
scons --use-system-all
See the SERVER-3829
349
and SERVER-5172
350
issues for more information.
Memory Allocator Changed to TCMalloc To improve performance, MongoDB 2.2 uses the TCMalloc memory
allocator from Google Perftools. For more information about this change see the SERVER-188
351
and SERVER-
4683
352
. For more information about TCMalloc, see the documentation of TCMalloc
353
itself.
Replication
Improved Logging for Replica Set Lag When secondary members of a replica set fall behind in replication,
mongod (page 555) now provides better reporting in the log. This makes it possible to track replication in general and
identify what process may produce errors or halt replication. See SERVER-3575
354
for more information.
Replica Set Members can Sync from Specic Members The new replSetSyncFrom (page 295) command
and new rs.syncFrom() (page 178) helper in the mongo (page 580) shell make it possible for you to manually
congure from which member of the set a replica will poll oplog entries. Use these commands to override the default
selection logic if needed. Always exercise caution with replSetSyncFrom (page 295) when overriding the default
behavior.
Replica Set Members will not Sync from Members Without Indexes Unless buildIndexes: false To
prevent inconsistency between members of replica sets, if the member of a replica set has buildIndexes set to
true, other members of the replica set will not sync from this member, unless they also have buildIndexes set
to true. See SERVER-4160
355
for more information.
348
https://jira.mongodb.org/browse/SERVER-4018
349
https://jira.mongodb.org/browse/SERVER-3829
350
https://jira.mongodb.org/browse/SERVER-5172
351
https://jira.mongodb.org/browse/SERVER-188
352
https://jira.mongodb.org/browse/SERVER-4683
353
http://goog-perftools.sourceforge.net/doc/tcmalloc.html
354
https://jira.mongodb.org/browse/SERVER-3575
355
https://jira.mongodb.org/browse/SERVER-4160
742 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
New Option To Congure Index Pre-Fetching during Replication By default, when replicating options, sec-
ondaries will pre-fetch indexes associated with a query to improve replication throughput in most cases. The
replication.secondaryIndexPrefetch setting and --replIndexPrefetch option allow administra-
tors to disable this feature or allow the mongod (page 555) to pre-fetch only the index on the _id eld. See SERVER-
6718
356
for more information.
Map Reduce Improvements
In 2.2 Map Reduce received the following improvements:
Improved support for sharded MapReduce
357
, and
MapReduce will retry jobs following a cong error
358
.
Sharding Improvements
Index on Shard Keys Can Now Be a Compound Index If your shard key uses the prex of an existing index,
then you do not need to maintain a separate index for your shard key in addition to your existing index. This index,
however, cannot be a multi-key index. See the sharding-shard-key-indexes documentation and SERVER-1506
359
for
more information.
Migration Thresholds Modied The migration thresholds have changed in 2.2 to permit more even distribution of
chunks in collections that have smaller quantities of data. See the sharding-migration-thresholds documentation for
more information.
Licensing Changes
Added License notice for Google Perftools (TCMalloc Utility). See the License Notice
360
and the SERVER-4683
361
for more information.
Resources
MongoDB Downloads
362
.
All JIRA issues resolved in 2.2
363
.
All backwards incompatible changes
364
.
All third party license notices
365
.
Whats New in MongoDB 2.2 Online Conference
366
.
356
https://jira.mongodb.org/browse/SERVER-6718
357
https://jira.mongodb.org/browse/SERVER-4521
358
https://jira.mongodb.org/browse/SERVER-4158
359
https://jira.mongodb.org/browse/SERVER-1506
360
https://github.com/mongodb/mongo/blob/v2.2/distsrc/THIRD-PARTY-NOTICES#L231
361
https://jira.mongodb.org/browse/SERVER-4683
362
http://mongodb.org/downloads
363
https://jira.mongodb.org/secure/IssueNavigator.jspa?reset=true&jqlQuery=project+%3D+SERVER+AND+xVersion+in+%28%222.1.0%22%2C+%222.1.1%22%2C+%222.1.2%22%2C+%222.2.0-
rc0%22%2C+%222.2.0-rc1%22%2C+%222.2.0-rc2%22%29+ORDER+BY+component+ASC%2C+key+DESC
364
https://jira.mongodb.org/issues/?lter=11225&jql=project%20%3D%20SERVER%20AND%20xVersion%20in%20(10483%2C%2010893%2C%2010894%2C%2010213)%20AND%20%22Backwards%20Compatibility%22%20in%20%20(%22Major%20Change%22%2C%20%22Minor%20Change%22)%20%20ORDER%20BY%20votes%20DESC%2C%20issuetype%20DESC%2C%20key%20DESC
365
https://github.com/mongodb/mongo/blob/v2.2/distsrc/THIRD-PARTY-NOTICES
366
http://www.mongodb.com/events/webinar/mongodb-online-conference-sept
7.2. Previous Stable Releases 743
MongoDB Reference Manual, Release 2.6.4
7.2.3 Release Notes for MongoDB 2.0
Upgrading
Although the major version number has changed, MongoDB 2.0 is a standard, incremental production release and
works as a drop-in replacement for MongoDB 1.8.
Preparation
Read through all release notes before upgrading, and ensure that no changes will affect your deployment.
If you create new indexes in 2.0, then downgrading to 1.8 is possible but you must reindex the new collections.
mongoimport (page 610) and mongoexport (page 616) now correctly adhere to the CSV spec for handling
CSV input/output. This may break existing import/export workows that relied on the previous behavior. For more
information see SERVER-1097
367
.
Journaling
368
is enabled by default in 2.0 for 64-bit builds. If you still prefer to run without journaling, start mongod
(page 555) with the --nojournal run-time option. Otherwise, MongoDB creates journal les during startup. The
rst time you start mongod (page 555) with journaling, you will see a delay as mongod (page 555) creates new les.
In addition, you may see reduced write throughput.
2.0 mongod (page 555) instances are interoperable with 1.8 mongod (page 555) instances; however, for best results,
upgrade your deployments using the following procedures:
Upgrading a Standalone mongod
1. Download the v2.0.x binaries from the MongoDB Download Page
369
.
2. Shutdown your mongod (page 555) instance. Replace the existing binary with the 2.0.x mongod (page 555)
binary and restart MongoDB.
Upgrading a Replica Set
1. Upgrade the secondary members of the set one at a time by shutting down the mongod (page 555) and replacing
the 1.8 binary with the 2.0.x binary from the MongoDB Download Page
370
.
2. To avoid losing the last few updates on failover you can temporarily halt your application (failover should take
less than 10 seconds), or you can set write concern in your application code to conrm that each update reaches
multiple servers.
3. Use the rs.stepDown() (page 177) to step down the primary to allow the normal failover procedure.
rs.stepDown() (page 177) and replSetStepDown (page 294) provide for shorter and more consistent
failover procedures than simply shutting down the primary directly.
When the primary has stepped down, shut down its instance and upgrade by replacing the mongod (page 555)
binary with the 2.0.x binary.
367
https://jira.mongodb.org/browse/SERVER-1097
368
http://www.mongodb.org/display/DOCS/Journaling
369
http://downloads.mongodb.org/
370
http://downloads.mongodb.org/
744 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Upgrading a Sharded Cluster
1. Upgrade all cong server instances rst, in any order. Since cong servers use two-phase commit, shard con-
guration metadata updates will halt until all are up and running.
2. Upgrade mongos (page 571) routers in any order.
Changes
Compact Command
A compact (page 316) command is now available for compacting a single collection and its indexes. Previously, the
only way to compact was to repair the entire database.
Concurrency Improvements
When going to disk, the server will yield the write lock when writing data that is not likely to be in memory. The
initial implementation of this feature now exists:
See SERVER-2563
371
for more information.
The specic operations yield in 2.0 are:
Updates by _id
Removes
Long cursor iterations
Default Stack Size
MongoDB 2.0 reduces the default stack size. This change can reduce total memory usage when there are many (e.g.,
1000+) client connections, as there is a thread per connection. While portions of a threads stack can be swapped out
if unused, some operating systems do this slowly enough that it might be an issue. The default stack size is lesser of
the system setting or 1MB.
Index Performance Enhancements
v2.0 includes signicant improvements to the index. Indexes are often 25% smaller and 25% faster (depends on the
use case). When upgrading from previous versions, the benets of the new index type are realized only if you create a
new index or re-index an old one.
Dates are now signed, and the max index key size has increased slightly from 819 to 1024 bytes.
All operations that create a new index will result in a 2.0 index by default. For example:
Reindexing results on an older-version index results in a 2.0 index. However, reindexing on a secondary does
not work in versions prior to 2.0. Do not reindex on a secondary. For a workaround, see SERVER-3866
372
.
The repairDatabase (page 332) command converts indexes to a 2.0 indexes.
371
https://jira.mongodb.org/browse/SERVER-2563
372
https://jira.mongodb.org/browse/SERVER-3866
7.2. Previous Stable Releases 745
MongoDB Reference Manual, Release 2.6.4
To convert all indexes for a given collection to the 2.0 type (page 745), invoke the compact (page 316) command.
Once you create new indexes, downgrading to 1.8.x will require a re-index of any indexes created using 2.0. See
http://docs.mongodb.org/manualtutorial/roll-back-to-v1.8-index.
Sharding Authentication
Applications can now use authentication with sharded clusters.
Replica Sets
Hidden Nodes in Sharded Clusters In 2.0, mongos (page 571) instances can now determine when a member of a
replica set becomes hidden without requiring a restart. In 1.8, mongos (page 571) if you recongured a member as
hidden, you had to restart mongos (page 571) to prevent queries from reaching the hidden member.
Priorities Each replica set member can now have a priority value consisting of a oating-point from 0 to 1000,
inclusive. Priorities let you control which member of the set you prefer to have as primary the member with the
highest priority that can see a majority of the set will be elected primary.
For example, suppose you have a replica set with three members, A, B, and C, and suppose that their priorities are set
as follows:
As priority is 2.
Bs priority is 3.
Cs priority is 1.
During normal operation, the set will always chose B as primary. If B becomes unavailable, the set will elect A as
primary.
For more information, see the priority documentation.
Data-Center Awareness You can now tag replica set members to indicate their location. You can use these tags
to design custom write rules across data centers, racks, specic servers, or any other architecture choice.
For example, an administrator can dene rules such as very important write or customerData or audit-trail to
replicate to certain servers, racks, data centers, etc. Then in the application code, the developer would say:
db.foo.insert(doc, {w : "very important write"})
which would succeed if it fullled the conditions the DBA dened for very important write.
For more information, see Tagging
373
.
Drivers may also support tag-aware reads. Instead of specifying slaveOk, you spec-
ify slaveOk with tags indicating which data-centers to read from. For details, see the
http://docs.mongodb.org/manualapplications/drivers documentation.
w : majority You can also set w to majority to ensure that the write propagates to a majority of nodes, ef-
fectively committing it. The value for majority will automatically adjust as you add or remove nodes from the
set.
For more information, see http://docs.mongodb.org/manualcore/write-concern.
373
http://www.mongodb.org/display/DOCS/Data+Center+Awareness#DataCenterAwareness-Tagging%28version2.0%29
746 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Reconguration with a Minority Up If the majority of servers in a set has been permanently lost, you can now
force a reconguration of the set to bring it back online.
For more information see http://docs.mongodb.org/manualtutorial/reconfigure-replica-set-with-unavailable-members.
Primary Checks for a Caught up Secondary before Stepping Down To minimize time without a primary, the
rs.stepDown() (page 177) method will now fail if the primary does not see a secondary within 10 seconds of its
latest optime. You can force the primary to step down anyway, but by default it will return an error message.
See also http://docs.mongodb.org/manualtutorial/force-member-to-be-primary.
Extended Shutdown on the Primary to Minimize Interruption When you call the shutdown (page 334) com-
mand, the primary will refuse to shut down unless there is a secondary whose optime is within 10 seconds of the
primary. If such a secondary isnt available, the primary will step down and wait up to a minute for the secondary to
be fully caught up before shutting down.
Note that to get this behavior, you must issue the shutdown (page 334) command explicitly; sending a signal to the
process will not trigger this behavior.
You can also force the primary to shut down, even without an up-to-date secondary available.
Maintenance Mode When repair or compact (page 316) runs on a secondary, the secondary will automatically
drop into recovering mode until the operation nishes. This prevents clients from trying to read from it while its
busy.
Geospatial Features
Multi-Location Documents Indexing is now supported on documents which have multiple location objects, em-
bedded either inline or in nested sub-documents. Additional command options are also supported, allowing results to
return with not only distance but the location used to generate the distance.
For more information, see Multi-location Documents
374
.
Polygon searches Polygonal $within (page 408) queries are also now supported for simple polygon shapes. For
details, see the $within (page 408) operator documentation.
Journaling Enhancements
Journaling is now enabled by default for 64-bit platforms. Use the --nojournal command line option to
disable it.
The journal is now compressed for faster commits to disk.
A new--journalCommitInterval run-time option exists for specifying your own group commit interval.
The default settings do not change.
A new { getLastError: { j: true } } (page 243) option is available to wait for the group com-
mit. The group commit will happen sooner when a client is waiting on {j: true}. If journaling is disabled,
{j: true} is a no-op.
374
http://www.mongodb.org/display/DOCS/Geospatial+Indexing#GeospatialIndexing-MultilocationDocuments
7.2. Previous Stable Releases 747
MongoDB Reference Manual, Release 2.6.4
New ContinueOnError Option for Bulk Insert
Set the continueOnError option for bulk inserts, in the driver, so that bulk insert will continue to insert any
remaining documents even if an insert fails, as is the case with duplicate key exceptions or network interruptions. The
getLastError (page 243) command will report whether any inserts have failed, not just the last one. If multiple
errors occur, the client will only receive the most recent getLastError (page 243) results.
See OP_INSERT
375
.
Note: For bulk inserts on sharded clusters, the getLastError (page 243) command alone is insufcient to verify
success. Applications should must verify the success of bulk inserts in application logic.
Map Reduce
Output to a Sharded Collection Using the new sharded ag, it is possible to send the result of a map/reduce to
a sharded collection. Combined with the reduce or merge ags, it is possible to keep adding data to very large
collections from map/reduce jobs.
For more information, see MapReduce Output Options
376
and mapReduce (page 218).
Performance Improvements Map/reduce performance will benet from the following:
Larger in-memory buffer sizes, reducing the amount of disk I/O needed during a job
Larger javascript heap size, allowing for larger objects and less GC
Supports pure JavaScript execution with the jsMode ag. See mapReduce (page 218).
New Querying Features
Additional regex options: s Allows the dot (.) to match all characters including new lines. This is in addition to
the currently supported i, m and x. See Regular Expressions
377
and $regex (page 399).
$and A special boolean $and (page 390) query operator is now available.
Command Output Changes
The output of the validate (page 374) command and the documents in the system.profile collection have
both been enhanced to return information as BSON objects with keys for each value rather than as free-form strings.
Shell Features
Custom Prompt You can dene a custom prompt for the mongo (page 580) shell. You can change the prompt at
any time by setting the prompt variable to a string or a custom JavaScript function returning a string. For examples,
see Custom Prompt
378
.
375
http://www.mongodb.org/display/DOCS/Mongo+Wire+Protocol#MongoWireProtocol-OPINSERT
376
http://www.mongodb.org/display/DOCS/MapReduce#MapReduce-Outputoptions
377
http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-RegularExpressions
378
http://www.mongodb.org/display/DOCS/Overview+-+The+MongoDB+Interactive+Shell#Overview-TheMongoDBInteractiveShell-
CustomPrompt
748 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Default Shell Init Script On startup, the shell will check for a .mongorc.js le in the users home directory.
The shell will execute this le after connecting to the database and before displaying the prompt.
If you would like the shell not to run the .mongorc.js le automatically, start the shell with --norc.
For more information, see mongo (page 580).
Most Commands Require Authentication
In 2.0, when running with authentication (e.g. authorization) all database commands require authentication,
except the following commands.
isMaster (page 287)
authenticate (page 261)
getnonce (page 262)
buildInfo (page 336)
ping (page 353)
isdbgrid (page 301)
Resources
MongoDB Downloads
379
All JIRA Issues resolved in 2.0
380
All Backward Incompatible Changes
381
7.2.4 Release Notes for MongoDB 1.8
Upgrading
MongoDB 1.8 is a standard, incremental production release and works as a drop-in replacement for MongoDB 1.6,
except:
Replica set members should be upgraded in a particular order, as described in Upgrading a Replica Set
(page 750).
The mapReduce (page 218) command has changed in 1.8, causing incompatibility with previous releases.
mapReduce (page 218) no longer generates temporary collections (thus, keepTemp has been removed). Now,
you must always supply a value for out. See the out eld options in the mapReduce (page 218) document.
If you use MapReduce, this also likely means you need a recent version of your client driver.
Preparation
Read through all release notes before upgrading and ensure that no changes will affect your deployment.
379
http://mongodb.org/downloads
380
https://jira.mongodb.org/secure/IssueNavigator.jspa?mode=hide&requestId=11002
381
https://jira.mongodb.org/issues/?lter=11023&jql=project%20%3D%20SERVER%20AND%20xVersion%20in%20(10889%2C%2010886%2C%2010784%2C%2010596%2C%2010380%2C%2010261%2C%2010232)%20AND%20%22Backwards%20Compatibility%22%20in%20%20(%22Major%20Change%22%2C%20%22Minor%20Change%22)%20ORDER%20BY%20votes%20DESC%2C%20issuetype%20DESC%2C%20key%20DESC
7.2. Previous Stable Releases 749
MongoDB Reference Manual, Release 2.6.4
Upgrading a Standalone mongod
1. Download the v1.8.x binaries from the MongoDB Download Page
382
.
2. Shutdown your mongod (page 555) instance.
3. Replace the existing binary with the 1.8.x mongod (page 555) binary.
4. Restart MongoDB.
Upgrading a Replica Set
1.8.x secondaries can replicate from 1.6.x primaries.
1.6.x secondaries cannot replicate from 1.8.x primaries.
Thus, to upgrade a replica set you must replace all of your secondaries rst, then the primary.
For example, suppose you have a replica set with a primary, an arbiter and several secondaries. To upgrade the set, do
the following:
1. For the arbiter:
(a) Shut down the arbiter.
(b) Restart it with the 1.8.x binary from the MongoDB Download Page
383
.
2. Change your cong (optional) to prevent election of a new primary.
It is possible that, when you start shutting down members of the set, a new primary will be elected. To prevent
this, you can give all of the secondaries a priority of 0 before upgrading, and then change them back afterwards.
To do so:
(a) Record your current cong. Run rs.config() (page 173) and paste the results into a text le.
(b) Update your cong so that all secondaries have priority 0. For example:
config = rs.conf()
{
"_id" : "foo",
"version" : 3,
"members" : [
{
"_id" : 0,
"host" : "ubuntu:27017"
},
{
"_id" : 1,
"host" : "ubuntu:27018"
},
{
"_id" : 2,
"host" : "ubuntu:27019",
"arbiterOnly" : true
}
{
"_id" : 3,
"host" : "ubuntu:27020"
},
382
http://downloads.mongodb.org/
383
http://downloads.mongodb.org/
750 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
{
"_id" : 4,
"host" : "ubuntu:27021"
},
]
}
config.version++
3
rs.isMaster()
{
"setName" : "foo",
"ismaster" : false,
"secondary" : true,
"hosts" : [
"ubuntu:27017",
"ubuntu:27018"
],
"arbiters" : [
"ubuntu:27019"
],
"primary" : "ubuntu:27018",
"ok" : 1
}
// for each secondary
config.members[0].priority = 0
config.members[3].priority = 0
config.members[4].priority = 0
rs.reconfig(config)
3. For each secondary:
(a) Shut down the secondary.
(b) Restart it with the 1.8.x binary from the MongoDB Download Page
384
.
4. If you changed the cong, change it back to its original state:
config = rs.conf()
config.version++
config.members[0].priority = 1
config.members[3].priority = 1
config.members[4].priority = 1
rs.reconfig(config)
5. Shut down the primary (the nal 1.6 server), and then restart it with the 1.8.x binary from the MongoDB
Download Page
385
.
Upgrading a Sharded Cluster
1. Turn off the balancer:
mongo <a_mongos_hostname>
use config
db.settings.update({_id:"balancer"},{$set : {stopped:true}}, true)
2. For each shard:
384
http://downloads.mongodb.org/
385
http://downloads.mongodb.org/
7.2. Previous Stable Releases 751
MongoDB Reference Manual, Release 2.6.4
If the shard is a replica set, follow the directions above for Upgrading a Replica Set (page 750).
If the shard is a single mongod (page 555) process, shut it down and then restart it with the 1.8.x binary
from the MongoDB Download Page
386
.
3. For each mongos (page 571):
(a) Shut down the mongos (page 571) process.
(b) Restart it with the 1.8.x binary from the MongoDB Download Page
387
.
4. For each cong server:
(a) Shut down the cong server process.
(b) Restart it with the 1.8.x binary from the MongoDB Download Page
388
.
5. Turn on the balancer:
use config
db.settings.update({_id:"balancer"},{$set : {stopped:false}})
Returning to 1.6
If for any reason you must move back to 1.6, follow the steps above in reverse. Please be careful that you have not
inserted any documents larger than 4MB while running on 1.8 (where the max size has increased to 16MB). If you
have you will get errors when the server tries to read those documents.
Journaling Returning to 1.6 after using 1.8 Journaling works ne, as journaling does not change anything about
the data le format. Suppose you are running 1.8.x with journaling enabled and you decide to switch back to 1.6. There
are two scenarios:
If you shut down cleanly with 1.8.x, just restart with the 1.6 mongod binary.
If 1.8.x shut down uncleanly, start 1.8.x up again and let the journal les run to x any damage (incomplete
writes) that may have existed at the crash. Then shut down 1.8.x cleanly and restart with the 1.6 mongod binary.
Changes
Journaling
MongoDB now supports write-ahead http://docs.mongodb.org/manualcore/journaling to facilitate
fast crash recovery and durability in the storage engine. With journaling enabled, a mongod (page 555) can be quickly
restarted following a crash without needing to repair the collections. The aggregation framework makes it possible to
do aggregation
Sparse and Covered Indexes
Sparse Indexes are indexes that only include documents that contain the elds specied in the index. Documents
missing the eld will not appear in the index at all. This can signicantly reduce index size for indexes of elds that
contain only a subset of documents within a collection.
386
http://downloads.mongodb.org/
387
http://downloads.mongodb.org/
388
http://downloads.mongodb.org/
752 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Covered Indexes enable MongoDB to answer queries entirely from the index when the query only selects elds that
the index contains.
Incremental MapReduce Support
The mapReduce (page 218) command supports new options that enable incrementally updating existing collections.
Previously, a MapReduce job could output either to a temporary collection or to a named permanent collection, which
it would overwrite with new data.
You now have several options for the output of your MapReduce jobs:
You can merge MapReduce output into an existing collection. Output from the Reduce phase will replace
existing keys in the output collection if it already exists. Other keys will remain in the collection.
You can now re-reduce your output with the contents of an existing collection. Each key output by the reduce
phase will be reduced with the existing document in the output collection.
You can replace the existing output collection with the new results of the MapReduce job (equivalent to setting
a permanent output collection in previous releases)
You can compute MapReduce inline and return results to the caller without persisting the results of the job. This
is similar to the temporary collections generated in previous releases, except results are limited to 8MB.
For more information, see the out eld options in the mapReduce (page 218) document.
Additional Changes and Enhancements
1.8.1
Sharding migrate x when moving larger chunks.
Durability x with background indexing.
Fixed mongos concurrency issue with many incoming connections.
1.8.0
All changes from 1.7.x series.
1.7.6
Bug xes.
1.7.5
Journaling.
Extent allocation improvements.
Improved replica set connectivity for mongos (page 571).
getLastError (page 243) improvements for sharding.
7.2. Previous Stable Releases 753
MongoDB Reference Manual, Release 2.6.4
1.7.4
mongos (page 571) routes slaveOk queries to secondaries in replica sets.
New mapReduce (page 218) output options.
index-type-sparse.
1.7.3
Initial covered index support.
Distinct can use data from indexes when possible.
mapReduce (page 218) can merge or reduce results into an existing collection.
mongod (page 555) tracks and mongostat (page 624) displays network usage. See mongostat (page 623).
Sharding stability improvements.
1.7.2
$rename (page 434) operator allows renaming of elds in a document.
db.eval() (page 113) not to block.
Geo queries with sharding.
mongostat --discover option
Chunk splitting enhancements.
Replica sets network enhancements for servers behind a nat.
1.7.1
Many sharding performance enhancements.
Better support for $elemMatch (page 425) on primitives in embedded arrays.
Query optimizer enhancements on range queries.
Window service enhancements.
Replica set setup improvements.
$pull (page 442) works on primitives in arrays.
1.7.0
Sharding performance improvements for heavy insert loads.
Slave delay support for replica sets.
getLastErrorDefaults for replica sets.
Auto completion in the shell.
Spherical distance for geo search.
All xes from 1.6.1 and 1.6.2.
754 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Release Announcement Forum Pages
1.8.1
389
, 1.8.0
390
1.7.6
391
, 1.7.5
392
, 1.7.4
393
, 1.7.3
394
, 1.7.2
395
, 1.7.1
396
, 1.7.0
397
Resources
MongoDB Downloads
398
All JIRA Issues resolved in 1.8
399
7.2.5 Release Notes for MongoDB 1.6
Upgrading
MongoDB 1.6 is a drop-in replacement for 1.4. To upgrade, simply shutdown mongod (page 555) then restart with
the new binaries.
Please note that you should upgrade to the latest version of whichever driver youre using. Certain drivers, including
the Ruby driver, will require the upgrade, and all the drivers will provide extra features for connecting to replica sets.
Sharding
http://docs.mongodb.org/manualsharding is now production-ready, making MongoDB horizontally
scalable, with no single point of failure. A single instance of mongod (page 555) can now be upgraded to a dis-
tributed cluster with zero downtime when the need arises.
http://docs.mongodb.org/manualsharding
http://docs.mongodb.org/manualtutorial/deploy-shard-cluster
http://docs.mongodb.org/manualtutorial/convert-replica-set-to-replicated-shard-cluster
Replica Sets
Replica sets, which provide automated failover among a cluster of n nodes, are also now available.
Please note that replica pairs are now deprecated; we strongly recommend that replica pair users upgrade to replica
sets.
http://docs.mongodb.org/manualreplication
http://docs.mongodb.org/manualtutorial/deploy-replica-set
http://docs.mongodb.org/manualtutorial/convert-standalone-to-replica-set
389
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/v09MbhEm62Y
390
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/JeHQOnam6Qk
391
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/3t6GNZ1qGYc
392
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/S5R0Tx9wkEg
393
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/9Om3Vuw-y9c
394
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/DfNUrdbmI
395
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/df7mwK6Xixo
396
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/HUR9zYtTpA8
397
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/TUnJCg9161A
398
http://mongodb.org/downloads
399
https://jira.mongodb.org/secure/IssueNavigator.jspa?mode=hide&requestId=10172
7.2. Previous Stable Releases 755
MongoDB Reference Manual, Release 2.6.4
Other Improvements
The w option (and wtimeout) forces writes to be propagated to n servers before returning success (this works
especially well with replica sets)
$or queries (page 393)
Improved concurrency
$slice (page 428) operator for returning subsets of arrays
64 indexes per collection (formerly 40 indexes per collection)
64-bit integers can now be represented in the shell using NumberLong
The findAndModify (page 237) command now supports upserts. It also allows you to specify elds to return
$showDiskLoc option to see disk location of a document
Support for IPv6 and UNIX domain sockets
Installation
Windows service improvements
The C++ client is a separate tarball from the binaries
1.6.x Release Notes
1.6.5
400
1.5.x Release Notes
1.5.8
401
1.5.7
402
1.5.6
403
1.5.5
404
1.5.4
405
1.5.3
406
1.5.2
407
1.5.1
408
1.5.0
409
400
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/06_QCC05Fpk
401
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/uJfF1QN6Thk
402
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/OYvz40RWs90
403
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/4l0N2U_H0cQ
404
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/oO749nvTARY
405
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/380V_Ec_q1c
406
https://groups.google.com/forum/?hl=en&fromgroups=#!topic/mongodb-user/hsUQL9CxTQw
407
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/94EE3HVidAA
408
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/7SBPQ2RSfdM
409
https://groups.google.com/forum/?fromgroups=#!topic/mongodb-user/VAhJcjDGTy0
756 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
You can see a full list of all changes on JIRA
410
.
Thank you everyone for your support and suggestions!
7.2.6 Release Notes for MongoDB 1.4
Upgrading
Were pleased to announce the 1.4 release of MongoDB. 1.4 is a drop-in replacement for 1.2. To upgrade you just
need to shutdown mongod (page 555), then restart with the new binaries. (Users upgrading from release 1.0 should
review the 1.2 release notes (page 758), in particular the instructions for upgrading the DB format.)
Release 1.4 includes the following improvements over release 1.2:
Core Server Enhancements
concurrency improvements
indexing memory improvements
background index creation
better detection of regular expressions so the index can be used in more cases
Replication and Sharding
better handling for restarting slaves ofine for a while
fast new slaves from snapshots (--fastsync)
congurable slave delay (--slavedelay)
replication handles clock skew on master
$inc (page 430) replication xes
sharding alpha 3 - notably 2-phase commit on cong servers
Deployment and Production
congure slow threshold for proling
ability to do fsync + lock (page 328) for backing up raw les
option for separate directory per db (--directoryperdb)
http://localhost:28017/_status to get serverStatus via http
REST interface is off by default for security (--rest to enable)
can rotate logs with a db command, logRotate (page 330)
enhancements to serverStatus (page 354) command (db.serverStatus()) - counters and replication lag stats
new mongostat (page 623) tool
410
https://jira.mongodb.org/secure/IssueNavigator.jspa?mode=hide&requestId=10107
7.2. Previous Stable Releases 757
MongoDB Reference Manual, Release 2.6.4
Query Language Improvements
$all (page 418) with regex
$not (page 392)
partial matching of array elements $elemMatch (page 425)
$ operator for updating arrays
$addToSet (page 439)
$unset (page 436)
$pull (page 442) supports object matching
$set (page 436) with array indexes
Geo
2d geospatial search
geo $center (page 413) and $box (page 412) searches
7.2.7 Release Notes for MongoDB 1.2.x
New Features
More indexes per collection
Faster index creation
Map/Reduce
Stored JavaScript functions
Congurable fsync time
Several small features and xes
DB Upgrade Required
There are some changes that will require doing an upgrade if your previous version is <= 1.0.x. If youre already using
a version >= 1.1.x then these changes arent required. There are 2 ways to do it:
--upgrade
stop your mongod (page 555) process
run ./mongod --upgrade
start mongod (page 555) again
use a slave
start a slave on a different port and data directory
when its synced, shut down the master, and start the new slave on the regular port.
Ask in the forums or IRC for more help.
758 Chapter 7. Release Notes
MongoDB Reference Manual, Release 2.6.4
Replication Changes
There have been minor changes in replication. If you are upgrading a master/slave setup from <= 1.1.2 you have
to update the slave rst.
mongoimport
mongoimportjson has been removed and is replaced with mongoimport (page 609) that can do json/csv/tsv
eld lter changing
Weve changed the semantics of the eld lter a little bit. Previously only objects with those elds would be
returned. Now the eld lter only changes the output, not which objects are returned. If you need that behavior,
you can use $exists (page 394)
7.3 Other MongoDB Release Notes
7.3.1 Default Write Concern Change
These release notes outline a change to all driver interfaces released in November 2012. See release notes for specic
drivers for additional information.
Changes
As of the releases listed below, there are two major changes to all drivers:
1. All drivers will add a new top-level connection class that will increase consistency for all MongoDB client
interfaces.
This change is non-backward breaking: existing connection classes will remain in all drivers for a time, and will
continue to operate as expected. However, those previous connection classes are now deprecated as of these
releases, and will eventually be removed from the driver interfaces.
The new top-level connection class is named MongoClient, or similar depending on how host languages
handle namespacing.
2. The default write concern on the new MongoClient class will be to acknowledge all write operations
411
.
This will allow your application to receive acknowledgment of all write operations.
See the documentation of Write Concern for more information about write concern in MongoDB.
Please migrate to the new MongoClient class expeditiously.
Releases
The following driver releases will include the changes outlined in Changes (page 759). See each drivers release notes
for a full account of each release as well as other related driver-specic changes.
C#, version 1.7
411
The drivers will call getLastError (page 243) without arguments, which is logically equivalent to the w: 1 option; how-
ever, this operation allows replica set users to override the default write concern with the getLastErrorDefaults setting in the
http://docs.mongodb.org/manualreference/replica-configuration.
7.3. Other MongoDB Release Notes 759
MongoDB Reference Manual, Release 2.6.4
Java, version 2.10.0
Node.js, version 1.2
Perl, version 0.501.1
PHP, version 1.4
Python, version 2.4
Ruby, version 1.8
760 Chapter 7. Release Notes
Index
Symbols
-{-}all
command line option 627
-{-}auditDestination
command line option 569, 578
-{-}auditFilter
command line option 570, 579
-{-}auditFormat
command line option 569, 578
-{-}auditPath
command line option 570, 579
-{-}auth
command line option 559
-{-}authenticationDatabase <dbname>
command line option 582, 593, 599, 607, 612, 619,
626, 633, 642
-{-}authenticationMechanism <name>
command line option 582, 593, 599, 607, 612, 619,
626, 633, 642
-{-}autoresync
command line option 565
-{-}bind_ip <ip address>
command line option 556, 572
-{-}chunkSize <value>
command line option 575
-{-}clusterAuthMode <option>
command line option 567, 576
-{-}collection <collection>, -c
command line option 594, 600, 608, 613, 620, 643
-{-}cong <lename>, -f
command line option 555, 571
-{-}congdb <cong1>,<cong2>,<cong3>
command line option 574
-{-}congsvr
command line option 565
-{-}cpu
command line option 560
-{-}csv
command line option 620
-{-}db <database>, -d
command line option 594, 600, 608, 613, 619, 643
-{-}dbpath <path>
command line option 560, 593, 600, 607, 613, 619,
643
-{-}diaglog <value>
command line option 557
-{-}directoryperdb
command line option 560, 594, 600, 608, 613, 619,
643
-{-}discover
command line option 627
-{-}drop
command line option 601, 614
-{-}dumpDbUsersAndRoles
command line option 595
-{-}eval <javascript>
command line option 580
-{-}fastsync
command line option 565
-{-}eldFile <lename>
command line option 613, 620
-{-}elds <eld1[,eld2]>, -f
command line option 613, 620
-{-}le <lename>
command line option 614
-{-}lter <JSON>
command line option 601, 603
-{-}forceTableScan
command line option 595, 621
-{-}fork
command line option 559, 574
-{-}forward <host><:port>
command line option 635
-{-}from <host[:port]>
command line option 608
-{-}headerline
command line option 614
-{-}help
command line option 590, 597, 603, 604, 610, 616,
624, 630, 635, 640
-{-}help, -h
761
MongoDB Reference Manual, Release 2.6.4
command line option 555, 571, 581, 637
-{-}host <hostname>
command line option 580
-{-}host <hostname><:port>
command line option 640
-{-}host <hostname><:port>, -h
command line option 591, 597, 605, 610, 616, 624,
631
-{-}http
command line option 627
-{-}httpinterface
command line option 558, 573
-{-}ignoreBlanks
command line option 614
-{-}install
command line option 587, 588
-{-}ipv6
command line option 559, 579, 581, 591, 597, 605,
610, 617, 624, 631, 640
-{-}journal
command line option 563, 594, 600, 608, 613, 619,
643
-{-}journalCommitInterval <value>
command line option 564
-{-}journalOptions <arguments>
command line option 564
-{-}jsonArray
command line option 614, 621
-{-}jsonp
command line option 559, 579
-{-}keepIndexVersion
command line option 601
-{-}keyFile <le>
command line option 558, 573
-{-}limit <number>
command line option 621
-{-}local <lename>, -l
command line option 643
-{-}localThreshold
command line option 574
-{-}locks
command line option 633
-{-}logappend
command line option 557, 572
-{-}logpath <path>
command line option 557, 572
-{-}master
command line option 565
-{-}maxConns <number>
command line option 556, 572
-{-}moveParanoia
command line option 566
-{-}noAutoSplit
command line option 575
-{-}noIndexBuildRetry
command line option 561
-{-}noIndexRestore
command line option 601
-{-}noOptionsRestore
command line option 601
-{-}noauth
command line option 559
-{-}nodb
command line option 580
-{-}noheaders
command line option 626
-{-}nohttpinterface
command line option 558
-{-}nojournal
command line option 563
-{-}noobjcheck
command line option 563, 601, 603
-{-}noprealloc
command line option 561
-{-}norc
command line option 580
-{-}noscripting
command line option 563, 579
-{-}notablescan
command line option 563
-{-}nounixsocket
command line option 558, 573
-{-}nssize <value>
command line option 561
-{-}objcheck
command line option 563, 600, 603, 636
-{-}only <arg>
command line option 565
-{-}oplog
command line option 594
-{-}oplogLimit <timestamp>
command line option 601
-{-}oplogReplay
command line option 601
-{-}oplogSize <value>
command line option 564
-{-}oplogns <namespace>
command line option 608
-{-}out <le>, -o
command line option 620
-{-}out <path>, -o
command line option 594
-{-}password <password>, -p
command line option 581, 593, 599, 607, 612, 618,
626, 632, 642
-{-}pidlepath <path>
command line option 558, 573
-{-}port
762 Index
MongoDB Reference Manual, Release 2.6.4
command line option 605
-{-}port <port>
command line option 556, 571, 580, 591, 597, 610,
617, 624, 631, 640
-{-}prole <level>
command line option 560
-{-}query <JSON>, -q
command line option 620
-{-}query <json>, -q
command line option 594
-{-}quiet
command line option 556, 571, 580, 591, 597, 603,
605, 610, 616, 630, 640
-{-}quota
command line option 561
-{-}quotaFiles <number>
command line option 561
-{-}reinstall
command line option 587, 588
-{-}remove
command line option 587, 588
-{-}repair
command line option 562, 595
-{-}repairpath <path>
command line option 563
-{-}replIndexPrefetch
command line option 564
-{-}replSet <setname>
command line option 564
-{-}replace, -r
command line option 644
-{-}rest
command line option 560
-{-}restoreDbUsersAndRoles
command line option 602
-{-}rowcount <number>, -n
command line option 627
-{-}seconds <number>, -s
command line option 608
-{-}serviceDescription <description>
command line option 587, 589
-{-}serviceDisplayName <name>
command line option 587, 589
-{-}serviceName name
command line option 587, 588
-{-}servicePassword <password>
command line option 588, 589
-{-}serviceUser <user>
command line option 587, 589
-{-}setParameter <options>
command line option 558, 573
-{-}shardsvr
command line option 566
-{-}shell
command line option 580
-{-}shutdown
command line option 564
-{-}skip <number>
command line option 621
-{-}slave
command line option 565
-{-}slaveOk, -k
command line option 621
-{-}slavedelay <value>
command line option 565
-{-}slowms <value>
command line option 560
-{-}smallles
command line option 562
-{-}snmp-master
command line option 570
-{-}snmp-subagent
command line option 570
-{-}sort <JSON>
command line option 621
-{-}source <NET [interface]>, <FILE [lename]>, <DIA-
GLOG [lename]>
command line option 635
-{-}source <host><:port>
command line option 565
-{-}ssl
command line option 582, 591, 598, 605, 611, 617,
624, 631, 641
-{-}sslAllowInvalidCerticates
command line option 568, 578, 583, 592, 599, 606,
612, 618, 625, 632, 642
-{-}sslCAFile <lename>
command line option 568, 577, 583, 591, 598, 605,
611, 617, 624, 631, 641
-{-}sslCRLFile <lename>
command line option 568, 577, 583, 592, 598, 606,
611, 618, 625, 632, 641
-{-}sslClusterFile <lename>
command line option 567, 576
-{-}sslClusterPassword <value>
command line option 568, 577
-{-}sslFIPSMode
command line option 569, 578, 583, 593, 599, 607,
612, 618, 626, 632, 642
-{-}sslMode <mode>
command line option 566, 575
-{-}sslOnNormalPorts
command line option 566, 575
-{-}sslPEMKeyFile <lename>
command line option 567, 576, 582, 592, 598, 606,
611, 617, 625, 631, 641
-{-}sslPEMKeyPassword <value>
Index 763
MongoDB Reference Manual, Release 2.6.4
command line option 567, 576, 582, 592, 598, 606,
611, 618, 625, 632, 641
-{-}sslWeakCerticateValidation
command line option 569, 577
-{-}stopOnError
command line option 614
-{-}syncdelay <value>
command line option 562
-{-}sysinfo
command line option 560
-{-}syslog
command line option 556, 572
-{-}syslogFacility <string>
command line option 557, 572
-{-}timeStampFormat <string>
command line option 557, 572
-{-}traceExceptions
command line option 558
-{-}type <=json|=debug>
command line option 603
-{-}type <MIME>
command line option 643
-{-}type <json|csv|tsv>
command line option 614
-{-}unixSocketPrex <path>
command line option 559, 573
-{-}upgrade
command line option 562, 575
-{-}upsert
command line option 614
-{-}upsertFields <eld1[,eld2]>
command line option 614
-{-}username <username>, -u
command line option 581, 593, 599, 607, 612, 618,
626, 632, 642
-{-}verbose
command line option 581
-{-}verbose, -v
command line option 556, 571, 591, 597, 603, 605,
610, 616, 624, 630, 640
-{-}version
command line option 555, 571, 581, 591, 597, 603,
605, 610, 616, 624, 630, 640
-{-}w <number of replicas per write>
command line option 602
555583, 587595, 597608, 610614, 616621, 624
627, 630633, 635637, 640644
$ (projection operator), 422
$ (update operator), 437
$add (aggregation framework transformation expression),
495
$addToSet (aggregation framework group expression),
521
$addToSet (update operator), 439
$all (query), 418
$allElementsTrue (aggregation framework transformation
expression), 480
$and (aggregation framework transformation expression),
477
$and (query), 390
$anyElementTrue (aggregation framework transformation
expression), 482
$atomic (update operator), 456
$avg (aggregation framework group expression), 522
$bit (update operator), 454
$box (query), 412
$center (query), 413
$centerSphere (query), 412
$cmd, 663
$cmp (aggregation framework transformation expres-
sion), 488
$comment (operator), 528
$concat (aggregation framework transformation expres-
sion), 499
$cond (aggregation framework transformation expres-
sion), 518
$currentDate (update operator), 429
$dayOfMonth (aggregation framework transformation ex-
pression), 509
$dayOfWeek (aggregation framework transformation ex-
pression), 510
$dayOfYear (aggregation framework transformation ex-
pression), 511
$divide (aggregation framework transformation expres-
sion), 496
$each (update operator), 446
$elemMatch (projection operator), 425
$elemMatch (query), 421
$eq (aggregation framework transformation expression),
489
$exists (query), 395
$explain (operator), 529
$rst (aggregation framework group expression), 522
$geoIntersects (query), 406
$geoNear (aggregation framework pipeline operator), 458
$geoWithin (query), 407
$geometry (query), 414
$group (aggregation framework pipeline operator), 460
$gt (aggregation framework transformation expression),
490
$gt (query), 386
$gte (aggregation framework transformation expression),
491
$gte (query), 387
$hint (operator), 529
$hour (aggregation framework transformation expres-
sion), 512
764 Index
MongoDB Reference Manual, Release 2.6.4
$ifNull (aggregation framework transformation expres-
sion), 520
$in (query), 387
$inc (update operator), 430
$isolated (update operator), 456
$last (aggregation framework group expression), 523
$let (aggregation framework transformation expression),
505
$limit (aggregation framework pipeline operator), 463
$literal (aggregation framework transformation expres-
sion), 507
$lt (aggregation framework transformation expression),
492
$lt (query), 388
$lte (aggregation framework transformation expression),
493
$lte (query), 389
$map (aggregation framework transformation expres-
sion), 506
$match (aggregation framework pipeline operator), 464
$max (aggregation framework group expression), 524
$max (operator), 530
$max (update operator), 430
$maxDistance (query), 414
$maxScan (operator), 530
$maxTimeMS (operator), 530
$meta (aggregation framework transformation expres-
sion), 503
$meta (projection operator), 427
$millisecond (aggregation framework transformation ex-
pression), 513
$min (aggregation framework group expression), 525
$min (operator), 531
$min (update operator), 431
$minDistance (query), 414
$minute (aggregation framework transformation expres-
sion), 514
$mod (aggregation framework transformation expres-
sion), 496
$mod (query), 398
$month (aggregation framework transformation expres-
sion), 515
$mul (update operator), 432
$multiply (aggregation framework transformation expres-
sion), 497
$natural (operator), 535
$ne (aggregation framework transformation expression),
493
$ne (query), 389
$near (query), 410
$nearSphere (query), 408
$nin (query), 390
$nor (query), 391
$not (aggregation framework transformation expression),
478
$not (query), 392
$options (operator), 399
$or (aggregation framework transformation expression),
479
$or (query), 393
$orderby (query), 532
$out (aggregation framework pipeline operator), 465
$polygon (query), 415
$pop (update operator), 440
$position (update operator), 447
$project (aggregation framework pipeline operator), 466
$pull (update operator), 442
$pullAll (update operator), 441
$push (aggregation framework group expression), 526
$push (update operator), 444
$pushAll (update operator), 444
$query (operator), 532
$redact (aggregation framework pipeline operator), 469
$regex (query), 399
$rename (update operator), 434
$returnKey (operator), 533
$second (aggregation framework transformation expres-
sion), 515
$set (update operator), 436
$setDifference (aggregation framework transformation
expression), 483
$setEquals (aggregation framework transformation ex-
pression), 484
$setIntersection (aggregation framework transformation
expression), 485
$setIsSubset (aggregation framework transformation ex-
pression), 486
$setOnInsert (update operator), 435
$setUnion (aggregation framework transformation ex-
pression), 487
$showDiskLoc (operator), 533
$size (aggregation framework transformation expression),
504
$size (query), 422
$skip (aggregation framework pipeline operator), 473
$slice (projection operator), 428
$slice (update operator), 449
$snapshot (operator), 534
$sort (aggregation framework pipeline operator), 473
$sort (update operator), 451
$strcasecmp (aggregation framework transformation ex-
pression), 499
$substr (aggregation framework transformation expres-
sion), 500
$subtract (aggregation framework transformation expres-
sion), 497
$sum (aggregation framework group expression), 527
Index 765
MongoDB Reference Manual, Release 2.6.4
$text (query), 401
$toLower (aggregation framework transformation expres-
sion), 501
$toUpper (aggregation framework transformation expres-
sion), 502
$type (query), 396
$uniqueDocs (query), 416
$unset (update operator), 436
$unwind (aggregation framework pipeline operator), 475
$week (aggregation framework transformation expres-
sion), 516
$where (query), 404
$within (query), 408
$year (aggregation framework transformation expres-
sion), 517
_hashBSONElement (database command), 380
_hashBSONElement.key (MongoDB reporting output),
381
_hashBSONElement.ok (MongoDB reporting output),
381
_hashBSONElement.out (MongoDB reporting output),
381
_hashBSONElement.seed (MongoDB reporting output),
381
_id, 664
_isSelf (database command), 352
_isWindows (shell method), 204
_migrateClone (database command), 378
_rand (shell method), 204
_recvChunkAbort (database command), 378
_recvChunkCommit (database command), 378
_recvChunkStart (database command), 378
_recvChunkStatus (database command), 378
_skewClockCommand (database command), 384
_srand (shell method), 205
_startMongoProgram (shell method), 194
_testDistLockWithSkew (database command), 385
_testDistLockWithSyncCluster (database command), 385
_transferMods (database command), 378
<database>.system.indexes (MongoDB reporting output),
655
<database>.system.js (MongoDB reporting output), 655
<database>.system.namespaces (MongoDB reporting
output), 655
<database>.system.prole (MongoDB reporting output),
655
0 (error code), 657
100 (error code), 658
12 (error code), 657
14 (error code), 657
2 (error code), 657
20 (error code), 657
2d Geospatial queries cannot use the $or operator (Mon-
goDB system limit), 662
3 (error code), 657
4 (error code), 657
45 (error code), 657
47 (error code), 657
48 (error code), 658
49 (error code), 658
5 (error code), 657
A
accumulator, 664
action, 664
addShard (database command), 296
admin database, 664
admin.system.roles (MongoDB reporting output), 655
admin.system.users (MongoDB reporting output), 655
admin.system.version (MongoDB reporting output), 655
aggregate (database command), 208
aggregation, 664
aggregation framework, 664
Aggregation Pipeline Operation (MongoDB system
limit), 662
applyOps (database command), 286
arbiter, 664
authenticate (database command), 261
authentication, 664
authorization, 664
authSchemaUpgrade (database command), 261
availableQueryOptions (database command), 336
B
B-tree, 664
balancer, 664
batchType (MongoDB reporting output), 146
BSON, 664
BSON Document Size (MongoDB system limit), 658
BSON types, 664
bsondump (program), 603
buildInfo (database command), 336
buildInfo (MongoDB reporting output), 337
buildInfo.allocator (MongoDB reporting output), 337
buildInfo.bits (MongoDB reporting output), 337
buildInfo.compilerFlags (MongoDB reporting output),
337
buildInfo.debug (MongoDB reporting output), 337
buildInfo.gitVersion (MongoDB reporting output), 337
buildInfo.javascriptEngine (MongoDB reporting output),
337
buildInfo.loaderFlags (MongoDB reporting output), 337
buildInfo.maxBsonObjectSize (MongoDB reporting out-
put), 338
buildInfo.sysInfo (MongoDB reporting output), 337
buildInfo.versionArray (MongoDB reporting output), 337
Bulk (shell method), 135
Bulk.execute (shell method), 136
766 Index
MongoDB Reference Manual, Release 2.6.4
Bulk.nd (shell method), 138
Bulk.nd.remove (shell method), 138
Bulk.nd.removeOne (shell method), 139
Bulk.nd.replaceOne (shell method), 139
Bulk.nd.update (shell method), 140
Bulk.nd.updateOne (shell method), 141
Bulk.nd.upsert (shell method), 142
Bulk.getOperations (shell method), 145
Bulk.insert (shell method), 146
Bulk.tojson (shell method), 147
Bulk.toString (shell method), 147
BulkWriteResult (shell method), 196
BulkWriteResult.nInserted (MongoDB reporting output),
196
BulkWriteResult.nMatched (MongoDB reporting out-
put), 196
BulkWriteResult.nModied (MongoDB reporting out-
put), 196
BulkWriteResult.nRemoved (MongoDB reporting out-
put), 196
BulkWriteResult.nUpserted (MongoDB reporting out-
put), 196
BulkWriteResult.upserted (MongoDB reporting output),
196
BulkWriteResult.upserted._id (MongoDB reporting out-
put), 196
BulkWriteResult.upserted.index (MongoDB reporting
output), 196
BulkWriteResult.writeConcernError (MongoDB report-
ing output), 197
BulkWriteResult.writeConcernError.code (MongoDB re-
porting output), 197
BulkWriteResult.writeConcernError.errInfo (MongoDB
reporting output), 197
BulkWriteResult.writeConcernError.errmsg (MongoDB
reporting output), 197
BulkWriteResult.writeErrors (MongoDB reporting out-
put), 196
BulkWriteResult.writeErrors.code (MongoDB reporting
output), 196
BulkWriteResult.writeErrors.errmsg (MongoDB report-
ing output), 196
BulkWriteResult.writeErrors.index (MongoDB reporting
output), 196
BulkWriteResult.writeErrors.op (MongoDB reporting
output), 196
C
CAP Theorem, 664
capped collection, 664
captrunc (database command), 382
cat (shell method), 205
cd (shell method), 205
checkShardingIndex (database command), 297
checksum, 664
chunk, 664
clean (database command), 312
cleanupOrphaned (database command), 298
cleanupOrphaned.ok (MongoDB reporting output), 299
cleanupOrphaned.stoppedAtKey (MongoDB reporting
output), 299
clearRawMongoProgramOutput (shell method), 194
client, 664
clone (database command), 313
cloneCollection (database command), 313
cloneCollectionAsCapped (database command), 312
closeAllDatabases (database command), 314
cluster, 664
collection, 665
system, 654
collection scan, 665
collMod (database command), 314
collStats (database command), 338
collStats.avgObjSize (MongoDB reporting output), 339
collStats.count (MongoDB reporting output), 338
collStats.ags (MongoDB reporting output), 339
collStats.indexSizes (MongoDB reporting output), 339
collStats.lastExtentSize (MongoDB reporting output),
339
collStats.nindexes (MongoDB reporting output), 339
collStats.ns (MongoDB reporting output), 338
collStats.numExtents (MongoDB reporting output), 339
collStats.paddingFactor (MongoDB reporting output),
339
collStats.size (MongoDB reporting output), 338
collStats.storageSize (MongoDB reporting output), 339
collStats.systemFlags (MongoDB reporting output), 339
collStats.totalIndexSize (MongoDB reporting output),
339
collStats.userFlags (MongoDB reporting output), 339
compact (database command), 316
compound index, 665
cong (MongoDB reporting output), 647
cong database, 665
cong server, 665
cong.changelog (MongoDB reporting output), 647
cong.changelog._id (MongoDB reporting output), 648
cong.changelog.clientAddr (MongoDB reporting out-
put), 648
cong.changelog.details (MongoDB reporting output),
649
cong.changelog.ns (MongoDB reporting output), 649
cong.changelog.server (MongoDB reporting output),
648
cong.changelog.time (MongoDB reporting output), 648
cong.changelog.what (MongoDB reporting output), 648
cong.chunks (MongoDB reporting output), 649
cong.collections (MongoDB reporting output), 649
Index 767
MongoDB Reference Manual, Release 2.6.4
cong.databases (MongoDB reporting output), 650
cong.lockpings (MongoDB reporting output), 650
cong.locks (MongoDB reporting output), 650
cong.mongos (MongoDB reporting output), 651
cong.settings (MongoDB reporting output), 651
cong.shards (MongoDB reporting output), 651
cong.tags (MongoDB reporting output), 652
cong.version (MongoDB reporting output), 652
congureFailPoint (database command), 383
connect (shell method), 203
connPoolStats (database command), 340
connPoolStats.createdByType (MongoDB reporting out-
put), 341
connPoolStats.createdByType.master (MongoDB report-
ing output), 341
connPoolStats.createdByType.set (MongoDB reporting
output), 341
connPoolStats.createdByType.sync (MongoDB reporting
output), 341
connPoolStats.hosts (MongoDB reporting output), 340
connPoolStats.hosts.[host].available (MongoDB report-
ing output), 340
connPoolStats.hosts.[host].created (MongoDB reporting
output), 340
connPoolStats.numAScopedConnection (MongoDB re-
porting output), 342
connPoolStats.numDBClientConnection (MongoDB re-
porting output), 342
connPoolStats.replicaSets (MongoDB reporting output),
340
connPoolStats.replicaSets.shard (MongoDB reporting
output), 340
connPoolStats.replicaSets.[shard].host (MongoDB
reporting output), 340
connPoolStats.replicaSets.[shard].host[n].addr (Mon-
goDB reporting output), 341
connPoolStats.replicaSets.[shard].host[n].hidden (Mon-
goDB reporting output), 341
connPoolStats.replicaSets.[shard].host[n].ismaster (Mon-
goDB reporting output), 341
connPoolStats.replicaSets.[shard].host[n].ok (MongoDB
reporting output), 341
connPoolStats.replicaSets.[shard].host[n].pingTimeMillis
(MongoDB reporting output), 341
connPoolStats.replicaSets.[shard].host[n].secondary
(MongoDB reporting output), 341
connPoolStats.replicaSets.[shard].host[n].tags (Mon-
goDB reporting output), 341
connPoolStats.replicaSets.[shard].master (MongoDB re-
porting output), 341
connPoolStats.replicaSets.[shard].nextSlave (MongoDB
reporting output), 341
connPoolStats.totalAvailable (MongoDB reporting out-
put), 341
connPoolStats.totalCreated (MongoDB reporting output),
342
connPoolSync (database command), 318
control script, 665
convertToCapped (database command), 318
copydb (database command), 319
copydbgetnonce (database command), 262
copyDbpath (shell method), 205
count (database command), 211
Covered Queries in Sharded Clusters (MongoDB system
limit), 661
create (database command), 326
createIndexes (database command), 322
createIndexes.code (MongoDB reporting output), 326
createIndexes.createdCollectionAutomatically (Mon-
goDB reporting output), 325
createIndexes.errmsg (MongoDB reporting output), 326
createIndexes.note (MongoDB reporting output), 326
createIndexes.numIndexesAfter (MongoDB reporting
output), 326
createIndexes.numIndexesBefore (MongoDB reporting
output), 325
createIndexes.ok (MongoDB reporting output), 326
createRole (database command), 272
createUser (database command), 263
CRUD, 665
CSV, 665
CURRENT (system variable available in aggregation),
546
currentOp.active (MongoDB reporting output), 110
currentOp.client (MongoDB reporting output), 111
currentOp.connectionId (MongoDB reporting output),
111
currentOp.desc (MongoDB reporting output), 111
currentOp.insert (MongoDB reporting output), 110
currentOp.killPending (MongoDB reporting output), 112
currentOp.locks (MongoDB reporting output), 111
currentOp.locks.^ (MongoDB reporting output), 111
currentOp.locks.^<database> (MongoDB reporting out-
put), 112
currentOp.locks.^local (MongoDB reporting output), 112
currentOp.lockStats (MongoDB reporting output), 112
currentOp.microsecs_running (MongoDB reporting out-
put), 110
currentOp.msg (MongoDB reporting output), 112
currentOp.ns (MongoDB reporting output), 110
currentOp.numYields (MongoDB reporting output), 112
currentOp.op (MongoDB reporting output), 110
currentOp.opid (MongoDB reporting output), 110
currentOp.planSummary (MongoDB reporting output),
111
currentOp.progress (MongoDB reporting output), 112
currentOp.progress.done (MongoDB reporting output),
112
768 Index
MongoDB Reference Manual, Release 2.6.4
currentOp.progress.total (MongoDB reporting output),
112
currentOp.query (MongoDB reporting output), 110
currentOp.secs_running (MongoDB reporting output),
110
currentOp.threadId (MongoDB reporting output), 111
currentOp.timeAcquiringMicros (MongoDB reporting
output), 113
currentOp.timeAcquiringMicros.R (MongoDB reporting
output), 113
currentOp.timeAcquiringMicros.r (MongoDB reporting
output), 113
currentOp.timeAcquiringMicros.W (MongoDB reporting
output), 113
currentOp.timeAcquiringMicros.w (MongoDB reporting
output), 113
currentOp.timeLockedMicros (MongoDB reporting out-
put), 112
currentOp.timeLockedMicros.R (MongoDB reporting
output), 113
currentOp.timeLockedMicros.r (MongoDB reporting out-
put), 113
currentOp.timeLockedMicros.W (MongoDB reporting
output), 113
currentOp.timeLockedMicros.w (MongoDB reporting
output), 113
currentOp.waitingForLock (MongoDB reporting output),
112
cursor, 665
cursor.addOption (shell method), 79
cursor.batchSize (shell method), 80
cursor.count (shell method), 81
cursor.explain (shell method), 83
cursor.forEach (shell method), 88
cursor.hasNext (shell method), 88
cursor.hint (shell method), 88
cursor.limit (shell method), 89
cursor.map (shell method), 89
cursor.max (shell method), 90
cursor.maxTimeMS (shell method), 91
cursor.min (shell method), 92
cursor.next (shell method), 93
cursor.objsLeftInBatch (shell method), 94
cursor.readPref (shell method), 94
cursor.showDiskLoc (shell method), 94
cursor.size (shell method), 95
cursor.skip (shell method), 95
cursor.snapshot (shell method), 96
cursor.sort (shell method), 96
cursor.toArray (shell method), 100
cursorInfo (database command), 342
D
daemon, 665
data directory, 665
Data Size (MongoDB system limit), 660
data-center awareness, 665
database, 665
local, 652
database command, 665
Database Name Case Sensitivity (MongoDB system
limit), 663
database proler, 665
dataSize (database command), 342
Date (shell method), 197
datum, 665
db.addUser (shell method), 101, 148
db.auth (shell method), 102
db.changeUserPassword (shell method), 103, 150
db.cloneCollection (shell method), 103
db.cloneDatabase (shell method), 104
db.collection.aggregate (shell method), 22
db.collection.copyTo (shell method), 25
db.collection.count (shell method), 26
db.collection.createIndex (shell method), 27
db.collection.dataSize (shell method), 28
db.collection.distinct (shell method), 28
db.collection.drop (shell method), 28
db.collection.dropIndex (shell method), 29
db.collection.dropIndexes (shell method), 30
db.collection.ensureIndex (shell method), 30
db.collection.nd (shell method), 33
db.collection.ndAndModify (shell method), 38
db.collection.ndOne (shell method), 42
db.collection.getIndexes (shell method), 45
db.collection.getIndexStats (shell method), 44
db.collection.getPlanCache (shell method), 133
db.collection.getShardDistribution (shell method), 45
db.collection.getShardVersion (shell method), 47
db.collection.group (shell method), 47
db.collection.indexStats (shell method), 51
db.collection.initializeOrderedBulkOp (shell method), 51
db.collection.initializeUnorderedBulkOp (shell method),
52
db.collection.insert (shell method), 53
db.collection.isCapped (shell method), 56
db.collection.mapReduce (shell method), 56
db.collection.reIndex (shell method), 63
db.collection.remove (shell method), 64
db.collection.renameCollection (shell method), 67
db.collection.save (shell method), 68
db.collection.stats (shell method), 69
db.collection.storageSize (shell method), 70
db.collection.totalIndexSize (shell method), 70
db.collection.totalSize (shell method), 70
db.collection.update (shell method), 70
db.collection.validate (shell method), 78
db.commandHelp (shell method), 104
Index 769
MongoDB Reference Manual, Release 2.6.4
db.copyDatabase (shell method), 104
db.createCollection (shell method), 106
db.createRole (shell method), 159
db.createUser (shell method), 150
db.currentOp (shell method), 107
db.dropAllRoles (shell method), 161
db.dropAllUsers (shell method), 152
db.dropDatabase (shell method), 113
db.dropRole (shell method), 161
db.dropUser (shell method), 153
db.eval (shell method), 113
db.fsyncLock (shell method), 115
db.fsyncUnlock (shell method), 115
db.getCollection (shell method), 116
db.getCollectionNames (shell method), 116
db.getLastError (shell method), 116
db.getLastErrorObj (shell method), 116
db.getMongo (shell method), 117
db.getName (shell method), 117
db.getPrevError (shell method), 117
db.getProlingLevel (shell method), 117
db.getProlingStatus (shell method), 117
db.getReplicationInfo (shell method), 117
db.getReplicationInfo.errmsg (MongoDB reporting out-
put), 118
db.getReplicationInfo.logSizeMB (MongoDB reporting
output), 118
db.getReplicationInfo.now (MongoDB reporting output),
118
db.getReplicationInfo.oplogMainRowCount (MongoDB
reporting output), 118
db.getReplicationInfo.tFirst (MongoDB reporting out-
put), 118
db.getReplicationInfo.timeDiff (MongoDB reporting out-
put), 118
db.getReplicationInfo.timeDiffHours (MongoDB report-
ing output), 118
db.getReplicationInfo.tLast (MongoDB reporting output),
118
db.getReplicationInfo.usedMB (MongoDB reporting out-
put), 118
db.getRole (shell method), 162
db.getRoles (shell method), 162
db.getSiblingDB (shell method), 118
db.getUser (shell method), 154
db.getUsers (shell method), 154
db.grantPrivilegesToRole (shell method), 163
db.grantRolesToRole (shell method), 164
db.grantRolesToUser (shell method), 154
db.help (shell method), 119
db.hostInfo (shell method), 119
db.isMaster (shell method), 120
db.killOp (shell method), 120
db.listCommands (shell method), 120
db.loadServerScripts (shell method), 120
db.logout (shell method), 121
db.printCollectionStats (shell method), 121
db.printReplicationInfo (shell method), 121
db.printShardingStatus (shell method), 122
db.printSlaveReplicationInfo (shell method), 123
db.removeUser (shell method), 123, 155
db.repairDatabase (shell method), 123
db.resetError (shell method), 124
db.revokePrivilegesFromRole (shell method), 165
db.revokeRolesFromRole (shell method), 167
db.revokeRolesFromUser (shell method), 156
db.runCommand (shell method), 124
db.serverBuildInfo (shell method), 124
db.serverCmdLineOpts (shell method), 124
db.serverStatus (shell method), 125
db.setProlingLevel (shell method), 125
db.shutdownServer (shell method), 125
db.stats (shell method), 126
db.updateRole (shell method), 169
db.updateUser (shell method), 157
db.upgradeCheck (shell method), 126
db.upgradeCheckAllDBs (shell method), 128
db.version (shell method), 129
dbHash (database command), 342
dbpath, 665
DBQuery.Option.awaitData (MongoDB reporting out-
put), 80
DBQuery.Option.exhaust (MongoDB reporting output),
80
DBQuery.Option.noTimeout (MongoDB reporting out-
put), 80
DBQuery.Option.oplogReplay (MongoDB reporting out-
put), 80
DBQuery.Option.partial (MongoDB reporting output), 80
DBQuery.Option.slaveOk (MongoDB reporting output),
80
DBQuery.Option.tailable (MongoDB reporting output),
80
dbStats (database command), 342
dbStats.avgObjSize (MongoDB reporting output), 343
dbStats.collections (MongoDB reporting output), 343
dbStats.dataFileVersion (MongoDB reporting output),
344
dbStats.dataFileVersion.major (MongoDB reporting out-
put), 344
dbStats.dataFileVersion.minor (MongoDB reporting out-
put), 344
dbStats.dataSize (MongoDB reporting output), 343
dbStats.db (MongoDB reporting output), 343
dbStats.leSize (MongoDB reporting output), 343
dbStats.indexes (MongoDB reporting output), 343
dbStats.indexSize (MongoDB reporting output), 343
dbStats.nsSizeMB (MongoDB reporting output), 343
770 Index
MongoDB Reference Manual, Release 2.6.4
dbStats.numExtents (MongoDB reporting output), 343
dbStats.objects (MongoDB reporting output), 343
dbStats.storageSize (MongoDB reporting output), 343
delayed member, 665
delete (database command), 232
delete.n (MongoDB reporting output), 234
delete.ok (MongoDB reporting output), 234
delete.writeConcernError (MongoDB reporting output),
234
delete.writeConcernError.code (MongoDB reporting out-
put), 234
delete.writeConcernError.errmsg (MongoDB reporting
output), 234
delete.writeErrors (MongoDB reporting output), 234
delete.writeErrors.code (MongoDB reporting output),
234
delete.writeErrors.errmsg (MongoDB reporting output),
234
delete.writeErrors.index (MongoDB reporting output),
234
DESCEND (system variable available in aggregation),
546
diagLogging (database command), 344
diagnostic log, 665
distinct (database command), 213
document, 666
space allocation, 314
dot notation, 666
draining, 666
driver, 666
driverOIDTest (database command), 344
drop (database command), 327
dropAllRolesFromDatabase (database command), 273
dropAllUsersFromDatabase (database command), 264
dropDatabase (database command), 327
dropIndexes (database command), 327
dropRole (database command), 274
dropUser (database command), 265
E
EDITOR, 584
election, 666
emptycapped (database command), 383
enableSharding (database command), 300
environment variable
EDITOR, 584
HOME, 584
HOMEDRIVE, 584
HOMEPATH, 584
eval (database command), 235
eventual consistency, 666
expireAfterSeconds, 315
explain.allPlans (MongoDB reporting output), 87
explain.clauses (MongoDB reporting output), 87
explain.clusteredType (MongoDB reporting output), 87
explain.cursor (MongoDB reporting output), 85
explain.lterSet (MongoDB reporting output), 87
explain.indexBounds (MongoDB reporting output), 86
explain.indexOnly (MongoDB reporting output), 86
explain.isMultiKey (MongoDB reporting output), 86
explain.millis (MongoDB reporting output), 86
explain.millisShardAvg (MongoDB reporting output), 87
explain.millisShardTotal (MongoDB reporting output),
87
explain.n (MongoDB reporting output), 86
explain.nChunkSkips (MongoDB reporting output), 86
explain.nscanned (MongoDB reporting output), 86
explain.nscannedAllPlans (MongoDB reporting output),
86
explain.nscannedObjects (MongoDB reporting output),
86
explain.nscannedObjectsAllPlans (MongoDB reporting
output), 86
explain.numQueries (MongoDB reporting output), 87
explain.numShards (MongoDB reporting output), 88
explain.nYields (MongoDB reporting output), 86
explain.oldPlan (MongoDB reporting output), 87
explain.scanAndOrder (MongoDB reporting output), 86
explain.server (MongoDB reporting output), 87
explain.shards (MongoDB reporting output), 87
expression, 666
F
failover, 666
features (database command), 344
eld, 666
eld path, 666
lemd5 (database command), 328
ndAndModify (database command), 237
rewall, 666
ushRouterCong (database command), 301
forceerror (database command), 383
fsync, 666
fsync (database command), 328
fuzzFile (shell method), 205
G
geohash, 666
GeoJSON, 666
geoNear (database command), 227
geoNear.ok (MongoDB reporting output), 231
geoNear.results (MongoDB reporting output), 230
geoNear.results[n].dis (MongoDB reporting output), 230
geoNear.results[n].obj (MongoDB reporting output), 230
geoNear.stats (MongoDB reporting output), 231
geoNear.stats.avgDistance (MongoDB reporting output),
231
Index 771
MongoDB Reference Manual, Release 2.6.4
geoNear.stats.maxDistance (MongoDB reporting output),
231
geoNear.stats.nscanned (MongoDB reporting output),
231
geoNear.stats.objectsLoaded (MongoDB reporting out-
put), 231
geoNear.stats.time (MongoDB reporting output), 231
geoSearch (database command), 231
geospatial, 666
geoWalk (database command), 231
getCmdLineOpts (database command), 344
getHostName (shell method), 205
getLastError (database command), 243
getLastError.code (MongoDB reporting output), 243
getLastError.connectionId (MongoDB reporting output),
243
getLastError.err (MongoDB reporting output), 243
getLastError.lastOp (MongoDB reporting output), 243
getLastError.n (MongoDB reporting output), 244
getLastError.ok (MongoDB reporting output), 243
getLastError.shards (MongoDB reporting output), 244
getLastError.singleShard (MongoDB reporting output),
244
getLastError.updatedExisting (MongoDB reporting out-
put), 244
getLastError.upserted (MongoDB reporting output), 244
getLastError.waited (MongoDB reporting output), 244
getLastError.wnote (MongoDB reporting output), 244
getLastError.wtime (MongoDB reporting output), 244
getLastError.wtimeout (MongoDB reporting output), 244
getLog (database command), 345
getMemInfo (shell method), 205
getnonce (database command), 262
getoptime (database command), 287
getParameter (database command), 330
getPrevError (database command), 245
getShardMap (database command), 301
getShardVersion (database command), 301
godinsert (database command), 384
grantPrivilegesToRole (database command), 275
grantRolesToRole (database command), 276
grantRolesToUser (database command), 266
GridFS, 666
group (database command), 214
H
handshake (database command), 378
hashed shard key, 666
haystack index, 666
hidden member, 666
HOME, 584
HOMEDRIVE, 584
hostInfo (database command), 345
hostInfo (MongoDB reporting output), 346
hostInfo.extra (MongoDB reporting output), 347
hostInfo.extra.alwaysFullSync (MongoDB reporting out-
put), 347
hostInfo.extra.cpuFeatures (MongoDB reporting output),
347
hostInfo.extra.cpuFrequencyMHz (MongoDB reporting
output), 347
hostInfo.extra.kernelVersion (MongoDB reporting out-
put), 347
hostInfo.extra.libcVersion (MongoDB reporting output),
347
hostInfo.extra.maxOpenFiles (MongoDB reporting out-
put), 347
hostInfo.extra.nfsAsync (MongoDB reporting output),
347
hostInfo.extra.numPages (MongoDB reporting output),
347
hostInfo.extra.pageSize (MongoDB reporting output),
347
hostInfo.extra.scheduler (MongoDB reporting output),
347
hostInfo.extra.versionString (MongoDB reporting out-
put), 347
hostInfo.os (MongoDB reporting output), 346
hostInfo.os.name (MongoDB reporting output), 346
hostInfo.os.type (MongoDB reporting output), 346
hostInfo.os.version (MongoDB reporting output), 346
hostInfo.system (MongoDB reporting output), 346
hostInfo.system.cpuAddrSize (MongoDB reporting out-
put), 346
hostInfo.system.cpuArch (MongoDB reporting output),
346
hostInfo.system.currentTime (MongoDB reporting out-
put), 346
hostInfo.system.hostname (MongoDB reporting output),
346
hostInfo.system.memSizeMB (MongoDB reporting out-
put), 346
hostInfo.system.numaEnabled (MongoDB reporting out-
put), 346
hostInfo.system.numCores (MongoDB reporting output),
346
hostname (shell method), 206
I
idempotent, 667
index, 667
index (collection ag), 315
Index Key Limit (MongoDB system limit), 658
Index Name Length (MongoDB system limit), 659
indexStats (database command), 347
indexStats.bucketBodyBytes (MongoDB reporting out-
put), 348
indexStats.depth (MongoDB reporting output), 348
772 Index
MongoDB Reference Manual, Release 2.6.4
indexStats.index (MongoDB reporting output), 348
indexStats.isIdIndex (MongoDB reporting output), 348
indexStats.keyPattern (MongoDB reporting output), 348
indexStats.overall (MongoDB reporting output), 348
indexStats.overall.bsonRatio (MongoDB reporting out-
put), 348
indexStats.overall.llRatio (MongoDB reporting output),
348
indexStats.overall.keyCount (MongoDB reporting out-
put), 348
indexStats.overall.keyNodeRatio (MongoDB reporting
output), 348
indexStats.overall.numBuckets (MongoDB reporting out-
put), 348
indexStats.overall.usedKeyCount (MongoDB reporting
output), 348
indexStats.perLevel (MongoDB reporting output), 348
indexStats.perLevel.bsonRatio (MongoDB reporting out-
put), 349
indexStats.perLevel.llRatio (MongoDB reporting out-
put), 349
indexStats.perLevel.keyCount (MongoDB reporting out-
put), 349
indexStats.perLevel.keyNodeRatio (MongoDB reporting
output), 349
indexStats.perLevel.numBuckets (MongoDB reporting
output), 349
indexStats.perLevel.usedKeyCount (MongoDB reporting
output), 349
indexStats.storageNs (MongoDB reporting output), 348
indexStats.version (MongoDB reporting output), 348
initial sync, 667
insert (database command), 245
insert.n (MongoDB reporting output), 246
insert.ok (MongoDB reporting output), 246
insert.writeConcernError (MongoDB reporting output),
247
insert.writeConcernError.code (MongoDB reporting out-
put), 247
insert.writeConcernError.errmsg (MongoDB reporting
output), 247
insert.writeErrors (MongoDB reporting output), 246
insert.writeErrors.code (MongoDB reporting output), 246
insert.writeErrors.errmsg (MongoDB reporting output),
247
insert.writeErrors.index (MongoDB reporting output),
246
internals
cong database, 647
interrupt point, 667
invalidateUserCache (database command), 277
IPv6, 667
isdbgrid (database command), 301
isMaster (database command), 287
isMaster.arbiterOnly (MongoDB reporting output), 289
isMaster.arbiters (MongoDB reporting output), 288
isMaster.hidden (MongoDB reporting output), 289
isMaster.hosts (MongoDB reporting output), 288
isMaster.ismaster (MongoDB reporting output), 287
isMaster.localTime (MongoDB reporting output), 288
isMaster.maxBsonObjectSize (MongoDB reporting out-
put), 288
isMaster.maxMessageSizeBytes (MongoDB reporting
output), 288
isMaster.maxWireVersion (MongoDB reporting output),
288
isMaster.me (MongoDB reporting output), 289
isMaster.minWireVersion (MongoDB reporting output),
288
isMaster.msg (MongoDB reporting output), 288
isMaster.passive (MongoDB reporting output), 289
isMaster.passives (MongoDB reporting output), 288
isMaster.primary (MongoDB reporting output), 289
isMaster.secondary (MongoDB reporting output), 288
isMaster.setName (MongoDB reporting output), 288
isMaster.tags (MongoDB reporting output), 289
ISODate, 667
J
JavaScript, 667
journal, 667
journalLatencyTest (database command), 382
JSON, 667
JSON document, 667
JSONP, 667
K
KEEP (system variable available in aggregation), 546
L
least privilege, 667
legacy coordinate pairs, 667
Length of Database Names (MongoDB system limit), 663
LineString, 667
listCommands (database command), 352
listDatabases (database command), 352
listFiles (shell method), 206
listShards (database command), 302
load (shell method), 206
local database, 652
local.oplog.$main (MongoDB reporting output), 654
local.oplog.rs (MongoDB reporting output), 654
local.replset.minvalid (MongoDB reporting output), 654
local.slaves (MongoDB reporting output), 654
local.sources (MongoDB reporting output), 654
local.startup_log (MongoDB reporting output), 653
local.startup_log._id (MongoDB reporting output), 653
Index 773
MongoDB Reference Manual, Release 2.6.4
local.startup_log.buildinfo (MongoDB reporting output),
653
local.startup_log.cmdLine (MongoDB reporting output),
653
local.startup_log.hostname (MongoDB reporting output),
653
local.startup_log.pid (MongoDB reporting output), 653
local.startup_log.startTime (MongoDB reporting output),
653
local.startup_log.startTimeLocal (MongoDB reporting
output), 653
local.system.replset (MongoDB reporting output), 654
lock, 667
logApplicationMessage (database command), 385
logout (database command), 262
logRotate (database command), 330
ls (shell method), 206
LVM, 667
M
map-reduce, 667
mapping type, 668
mapReduce (database command), 218
mapReduce.counts (MongoDB reporting output), 226
mapReduce.counts.emit (MongoDB reporting output),
226
mapReduce.counts.input (MongoDB reporting output),
226
mapReduce.counts.output (MongoDB reporting output),
226
mapReduce.counts.reduce (MongoDB reporting output),
226
mapReduce.ok (MongoDB reporting output), 226
mapReduce.result (MongoDB reporting output), 226
mapReduce.results (MongoDB reporting output), 226
mapreduce.shardednish (database command), 379
mapReduce.timeMillis (MongoDB reporting output), 226
master, 668
Maximum Number of Documents in a Capped Collection
(MongoDB system limit), 660
Maximum Size of Auto-Created Oplog (MongoDB sys-
tem limit), 660
md5, 668
md5sumFile (shell method), 206
medianKey (database command), 302
mergeChunks (database command), 302
MIB, 668
MIME, 668
mkdir (shell method), 207
mongo, 668
mongo (program), 580
Mongo (shell method), 200
Mongo.getDB (shell method), 200
Mongo.getReadPrefMode (shell method), 201
Mongo.getReadPrefTagSet (shell method), 201
Mongo.setReadPref (shell method), 202
Mongo.setSlaveOk (shell method), 202
mongod, 668
mongod (program), 555
mongod.exe (program), 587
MongoDB, 668
MongoDB Enterprise, 668
mongodump (program), 590
mongoexport (program), 616
mongoles (program), 639, 640
mongoimport (program), 610
mongooplog (program), 604
mongoperf (program), 637
mongoperf.leSizeMB (setting), 638
mongoperf.mmf (setting), 638
mongoperf.nThreads (setting), 638
mongoperf.r (setting), 638
mongoperf.recSizeKB (setting), 638
mongoperf.sleepMicros (setting), 638
mongoperf.syncDelay (setting), 639
mongoperf.w (setting), 638
mongorestore (program), 597
mongos, 668
mongos (program), 571
mongos.exe (program), 588
mongosniff (program), 635
mongostat (program), 624
mongotop (program), 630
mongotop.<timestamp> (MongoDB reporting output),
634
mongotop.db (MongoDB reporting output), 634
mongotop.ns (MongoDB reporting output), 633
mongotop.read (MongoDB reporting output), 634
mongotop.total (MongoDB reporting output), 634
mongotop.write (MongoDB reporting output), 634
Monotonically Increasing Shard Keys Can Limit Insert
Throughput (MongoDB system limit), 662
moveChunk (database command), 303
movePrimary (database command), 304
N
namespace, 668
local, 652
system, 654
Namespace Length (MongoDB system limit), 658
natural order, 668
Nested Depth for BSON Documents (MongoDB system
limit), 658
netstat (database command), 353
Number of Collections in a Database (MongoDB system
limit), 660
Number of Indexed Fields in a Compound Index (Mon-
goDB system limit), 659
774 Index
MongoDB Reference Manual, Release 2.6.4
Number of Indexes per Collection (MongoDB system
limit), 659
Number of Members of a Replica Set (MongoDB system
limit), 660
Number of Namespaces (MongoDB system limit), 658
Number of Voting Members of a Replica Set (MongoDB
system limit), 660
O
ObjectId, 668
ObjectId.getTimestamp (shell method), 197
ObjectId.toString (shell method), 197
ObjectId.valueOf (shell method), 198
operations (MongoDB reporting output), 146
Operations Unavailable in Sharded Environments (Mon-
goDB system limit), 661
operator, 668
oplog, 668
ordered query plan, 669
originalZeroIndex (MongoDB reporting output), 146
orphaned document, 669
P
padding, 669
padding factor, 669
page fault, 669
parallelCollectionScan (database command), 247
parallelCollectionScan.cursors (MongoDB reporting out-
put), 248
parallelCollectionScan.cursors.cursor (MongoDB report-
ing output), 248
parallelCollectionScan.cursors.cursor.rstBatch (Mon-
goDB reporting output), 248
parallelCollectionScan.cursors.cursor.id (MongoDB re-
porting output), 248
parallelCollectionScan.cursors.cursor.ns (MongoDB re-
porting output), 248
parallelCollectionScan.cursors.ok (MongoDB reporting
output), 248
parallelCollectionScan.ok (MongoDB reporting output),
248
partition, 669
passive member, 669
pcap, 669
PID, 669
ping (database command), 353
pipe, 669
pipeline, 669
PlanCache.clear (shell method), 130
PlanCache.clearPlansByQuery (shell method), 130
PlanCache.getPlansByQuery (shell method), 131
PlanCache.help (shell method), 132
PlanCache.listQueryShapes (shell method), 132
planCacheClear (database command), 255
planCacheClearFilters (database command), 253
planCacheListFilters (database command), 256
planCacheListFilters.lters (MongoDB reporting output),
257
planCacheListFilters.lters.indexes (MongoDB reporting
output), 257
planCacheListFilters.lters.projection (MongoDB report-
ing output), 257
planCacheListFilters.lters.query (MongoDB reporting
output), 257
planCacheListFilters.lters.sort (MongoDB reporting
output), 257
planCacheListFilters.ok (MongoDB reporting output),
257
planCacheListPlans (database command), 257
planCacheListQueryShapes (database command), 258
planCacheSetFilter (database command), 260
Point, 669
Polygon, 669
powerOf2Sizes, 669
pre-splitting, 669
primary, 669
primary key, 670
primary shard, 670
priority, 670
privilege, 670
prole (database command), 353
projection, 670
PRUNE (system variable available in aggregation), 546
pwd (shell method), 207
Q
Queries cannot use both text and Geospatial Indexes
(MongoDB system limit), 659
query, 670
query optimizer, 670
query shape, 670
quit (shell method), 207
R
rawMongoProgramOutput (shell method), 194
RDBMS, 670
read lock, 670
read preference, 670
record size, 670
recovering, 670
reIndex (database command), 330
removeFile (shell method), 207
removeShard (database command), 305
renameCollection (database command), 331
repairDatabase (database command), 332
replica pairs, 670
replica set, 670
local database, 652
Index 775
MongoDB Reference Manual, Release 2.6.4
replication, 670
replication lag, 670
replSetElect (database command), 379
replSetFreeze (database command), 289
replSetFresh (database command), 378
replSetGetRBID (database command), 379
replSetGetStatus (database command), 289
replSetGetStatus.date (MongoDB reporting output), 291
replSetGetStatus.members (MongoDB reporting output),
291
replSetGetStatus.members.electionDate (MongoDB re-
porting output), 292
replSetGetStatus.members.electionTime (MongoDB re-
porting output), 292
replSetGetStatus.members.electionTime.i (MongoDB re-
porting output), 292
replSetGetStatus.members.electionTime.t (MongoDB re-
porting output), 292
replSetGetStatus.members.health (MongoDB reporting
output), 291
replSetGetStatus.members.lastHeartbeat (MongoDB re-
porting output), 292
replSetGetStatus.members.lastHeartbeatMessage (Mon-
goDB reporting output), 292
replSetGetStatus.members.lastHeartbeatRecv (Mon-
goDB reporting output), 292
replSetGetStatus.members.name (MongoDB reporting
output), 291
replSetGetStatus.members.optime (MongoDB reporting
output), 291
replSetGetStatus.members.optime.i (MongoDB reporting
output), 291
replSetGetStatus.members.optime.t (MongoDB reporting
output), 291
replSetGetStatus.members.optimeDate (MongoDB re-
porting output), 291
replSetGetStatus.members.pingMs (MongoDB reporting
output), 292
replSetGetStatus.members.self (MongoDB reporting out-
put), 291, 292
replSetGetStatus.members.state (MongoDB reporting
output), 291
replSetGetStatus.members.stateStr (MongoDB reporting
output), 291
replSetGetStatus.members.uptime (MongoDB reporting
output), 291
replSetGetStatus.myState (MongoDB reporting output),
291
replSetGetStatus.set (MongoDB reporting output), 291
replSetGetStatus.syncingTo (MongoDB reporting out-
put), 292
replSetHeartbeat (database command), 379
replSetInitiate (database command), 292
replSetMaintenance (database command), 293
replSetRecong (database command), 294
replSetStepDown (database command), 294
replSetSyncFrom (database command), 295
replSetTest (database command), 384
resetDbpath (shell method), 207
resetError (database command), 248
resident memory, 670
resource, 670
REST, 671
Restriction on Collection Names (MongoDB system
limit), 663
Restrictions on Database Names for Unix and Linux Sys-
tems (MongoDB system limit), 663
Restrictions on Database Names for Windows (MongoDB
system limit), 663
Restrictions on Field Names (MongoDB system limit),
663
resync (database command), 295
revokePrivilegesFromRole (database command), 277
revokeRolesFromRole (database command), 280
revokeRolesFromUser (database command), 267
RFC
RFC 4180, 614
role, 671
rolesInfo (database command), 281
rolesInfo.db (MongoDB reporting output), 282
rolesInfo.indirectRoles (MongoDB reporting output), 282
rolesInfo.isBuiltin (MongoDB reporting output), 282
rolesInfo.privileges (MongoDB reporting output), 282
rolesInfo.role (MongoDB reporting output), 282
rolesInfo.roles (MongoDB reporting output), 282
rollback, 671
ROOT (system variable available in aggregation), 546
rs.add (shell method), 172
rs.addArb (shell method), 173
rs.conf (shell method), 173
rs.cong (shell method), 173
rs.freeze (shell method), 173
rs.help (shell method), 173
rs.initiate (shell method), 173
rs.printReplicationInfo (shell method), 174
rs.printSlaveReplicationInfo (shell method), 174
rs.recong (shell method), 175
rs.remove (shell method), 177
rs.slaveOk (shell method), 177
rs.status (shell method), 177
rs.stepDown (shell method), 177
rs.syncFrom (shell method), 178
run (shell method), 194
runMongoProgram (shell method), 194
runProgram (shell method), 194
S
secondary, 671
776 Index
MongoDB Reference Manual, Release 2.6.4
secondary index, 671
serverStatus (database command), 354
serverStatus.asserts (MongoDB reporting output), 364
serverStatus.asserts.msg (MongoDB reporting output),
364
serverStatus.asserts.regular (MongoDB reporting output),
364
serverStatus.asserts.rollovers (MongoDB reporting out-
put), 364
serverStatus.asserts.user (MongoDB reporting output),
364
serverStatus.asserts.warning (MongoDB reporting out-
put), 364
serverStatus.backgroundFlushing (MongoDB reporting
output), 360
serverStatus.backgroundFlushing.average_ms (Mon-
goDB reporting output), 361
serverStatus.backgroundFlushing.ushes (MongoDB re-
porting output), 361
serverStatus.backgroundFlushing.last_nished (Mon-
goDB reporting output), 361
serverStatus.backgroundFlushing.last_ms (MongoDB re-
porting output), 361
serverStatus.backgroundFlushing.total_ms (MongoDB
reporting output), 361
serverStatus.connections (MongoDB reporting output),
359
serverStatus.connections.available (MongoDB reporting
output), 359
serverStatus.connections.current (MongoDB reporting
output), 359
serverStatus.connections.totalCreated (MongoDB report-
ing output), 359
serverStatus.cursors (MongoDB reporting output), 361
serverStatus.cursors.clientCursors_size (MongoDB re-
porting output), 361
serverStatus.cursors.note (MongoDB reporting output),
361
serverStatus.cursors.pinned (MongoDBreporting output),
362
serverStatus.cursors.timedOut (MongoDB reporting out-
put), 361
serverStatus.cursors.totalNoTimeout (MongoDB report-
ing output), 361
serverStatus.cursors.totalOpen (MongoDB reporting out-
put), 361
serverStatus.dur (MongoDB reporting output), 365
serverStatus.dur.commits (MongoDB reporting output),
365
serverStatus.dur.commitsInWriteLock (MongoDBreport-
ing output), 365
serverStatus.dur.compression (MongoDB reporting out-
put), 365
serverStatus.dur.earlyCommits (MongoDB reporting out-
put), 365
serverStatus.dur.journaledMB (MongoDB reporting out-
put), 365
serverStatus.dur.timeMS (MongoDB reporting output),
365
serverStatus.dur.timeMS.dt (MongoDB reporting output),
365
serverStatus.dur.timeMS.prepLogBuffer (MongoDB re-
porting output), 365
serverStatus.dur.timeMS.remapPrivateView (MongoDB
reporting output), 366
serverStatus.dur.timeMS.writeToDataFiles (MongoDB
reporting output), 366
serverStatus.dur.timeMS.writeToJournal (MongoDB re-
porting output), 366
serverStatus.dur.writeToDataFilesMB (MongoDB report-
ing output), 365
serverStatus.extra_info (MongoDB reporting output), 359
serverStatus.extra_info.heap_usage_bytes (MongoDB re-
porting output), 360
serverStatus.extra_info.note (MongoDB reporting out-
put), 359
serverStatus.extra_info.page_faults (MongoDB reporting
output), 360
serverStatus.globalLock (MongoDB reporting output),
357
serverStatus.globalLock.activeClients (MongoDB report-
ing output), 358
serverStatus.globalLock.activeClients.readers (Mon-
goDB reporting output), 358
serverStatus.globalLock.activeClients.total (MongoDB
reporting output), 358
serverStatus.globalLock.activeClients.writers (MongoDB
reporting output), 358
serverStatus.globalLock.currentQueue (MongoDB
reporting output), 358
serverStatus.globalLock.currentQueue.readers (Mon-
goDB reporting output), 358
serverStatus.globalLock.currentQueue.total (MongoDB
reporting output), 358
serverStatus.globalLock.currentQueue.writers (Mon-
goDB reporting output), 358
serverStatus.globalLock.lockTime (MongoDB reporting
output), 357
serverStatus.globalLock.ratio (MongoDB reporting out-
put), 357
serverStatus.globalLock.totalTime (MongoDB reporting
output), 357
serverStatus.host (MongoDB reporting output), 355
serverStatus.indexCounters (MongoDB reporting output),
360
serverStatus.indexCounters.accesses (MongoDB report-
ing output), 360
Index 777
MongoDB Reference Manual, Release 2.6.4
serverStatus.indexCounters.hits (MongoDB reporting
output), 360
serverStatus.indexCounters.misses (MongoDB reporting
output), 360
serverStatus.indexCounters.missRatio (MongoDB report-
ing output), 360
serverStatus.indexCounters.resets (MongoDB reporting
output), 360
serverStatus.localTime (MongoDB reporting output), 355
serverStatus.locks (MongoDB reporting output), 355
serverStatus.locks.. (MongoDB reporting output), 355
serverStatus.locks...timeAcquiringMicros (MongoDB re-
porting output), 356
serverStatus.locks...timeAcquiringMicros.R (MongoDB
reporting output), 356
serverStatus.locks...timeAcquiringMicros.W (MongoDB
reporting output), 356
serverStatus.locks...timeLockedMicros (MongoDB re-
porting output), 355
serverStatus.locks...timeLockedMicros.R (MongoDB re-
porting output), 355
serverStatus.locks...timeLockedMicros.r (MongoDB re-
porting output), 356
serverStatus.locks...timeLockedMicros.W (MongoDB re-
porting output), 355
serverStatus.locks...timeLockedMicros.w (MongoDB re-
porting output), 356
serverStatus.locks.<database> (MongoDB reporting out-
put), 357
serverStatus.locks.<database>.timeAcquiringMicros
(MongoDB reporting output), 357
serverStatus.locks.<database>.timeAcquiringMicros.r
(MongoDB reporting output), 357
serverStatus.locks.<database>.timeAcquiringMicros.w
(MongoDB reporting output), 357
serverStatus.locks.<database>.timeLockedMicros (Mon-
goDB reporting output), 357
serverStatus.locks.<database>.timeLockedMicros.r
(MongoDB reporting output), 357
serverStatus.locks.<database>.timeLockedMicros.w
(MongoDB reporting output), 357
serverStatus.locks.admin (MongoDB reporting output),
356
serverStatus.locks.admin.timeAcquiringMicros (Mon-
goDB reporting output), 356
serverStatus.locks.admin.timeAcquiringMicros.r (Mon-
goDB reporting output), 356
serverStatus.locks.admin.timeAcquiringMicros.w (Mon-
goDB reporting output), 356
serverStatus.locks.admin.timeLockedMicros (MongoDB
reporting output), 356
serverStatus.locks.admin.timeLockedMicros.r (Mon-
goDB reporting output), 356
serverStatus.locks.admin.timeLockedMicros.w (Mon-
goDB reporting output), 356
serverStatus.locks.local (MongoDB reporting output),
356
serverStatus.locks.local.timeAcquiringMicros (Mon-
goDB reporting output), 356
serverStatus.locks.local.timeAcquiringMicros.r (Mon-
goDB reporting output), 357
serverStatus.locks.local.timeAcquiringMicros.w (Mon-
goDB reporting output), 357
serverStatus.locks.local.timeLockedMicros (MongoDB
reporting output), 356
serverStatus.locks.local.timeLockedMicros.r (MongoDB
reporting output), 356
serverStatus.locks.local.timeLockedMicros.w (Mon-
goDB reporting output), 356
serverStatus.mem (MongoDB reporting output), 358
serverStatus.mem.bits (MongoDB reporting output), 358
serverStatus.mem.mapped (MongoDB reporting output),
359
serverStatus.mem.mappedWithJournal (MongoDB
reporting output), 359
serverStatus.mem.resident (MongoDB reporting output),
358
serverStatus.mem.supported (MongoDB reporting out-
put), 359
serverStatus.mem.virtual (MongoDB reporting output),
359
serverStatus.metrics (MongoDB reporting output), 367
serverStatus.metrics.cursor (MongoDB reporting output),
371
serverStatus.metrics.cursor.open (MongoDB reporting
output), 371
serverStatus.metrics.cursor.open.noTimeout (MongoDB
reporting output), 371
serverStatus.metrics.cursor.open.pinned (MongoDB re-
porting output), 371
serverStatus.metrics.cursor.open.total (MongoDB report-
ing output), 371
serverStatus.metrics.cursor.timedOut (MongoDB report-
ing output), 371
serverStatus.metrics.document (MongoDB reporting out-
put), 367
serverStatus.metrics.document.deleted (MongoDB
reporting output), 368
serverStatus.metrics.document.inserted (MongoDB re-
porting output), 368
serverStatus.metrics.document.returned (MongoDB re-
porting output), 368
serverStatus.metrics.document.updated (MongoDB re-
porting output), 368
serverStatus.metrics.getLastError (MongoDB reporting
output), 368
778 Index
MongoDB Reference Manual, Release 2.6.4
serverStatus.metrics.getLastError.wtime (MongoDB re-
porting output), 368
serverStatus.metrics.getLastError.wtime.num (MongoDB
reporting output), 368
serverStatus.metrics.getLastError.wtime.totalMillis
(MongoDB reporting output), 368
serverStatus.metrics.getLastError.wtimeouts (MongoDB
reporting output), 368
serverStatus.metrics.operation (MongoDB reporting out-
put), 368
serverStatus.metrics.operation.fastmod (MongoDB re-
porting output), 368
serverStatus.metrics.operation.idhack (MongoDB report-
ing output), 368
serverStatus.metrics.operation.scanAndOrder (MongoDB
reporting output), 368
serverStatus.metrics.queryExecutor (MongoDB reporting
output), 368
serverStatus.metrics.queryExecutor.scanned (MongoDB
reporting output), 368
serverStatus.metrics.record (MongoDB reporting output),
368
serverStatus.metrics.record.moves (MongoDB reporting
output), 368
serverStatus.metrics.repl (MongoDB reporting output),
369
serverStatus.metrics.repl.apply (MongoDB reporting out-
put), 369
serverStatus.metrics.repl.apply.batches (MongoDB re-
porting output), 369
serverStatus.metrics.repl.apply.batches.num (MongoDB
reporting output), 369
serverStatus.metrics.repl.apply.batches.totalMillis (Mon-
goDB reporting output), 369
serverStatus.metrics.repl.apply.ops (MongoDB reporting
output), 369
serverStatus.metrics.repl.buffer (MongoDBreporting out-
put), 369
serverStatus.metrics.repl.buffer.count (MongoDB report-
ing output), 369
serverStatus.metrics.repl.buffer.maxSizeBytes (Mon-
goDB reporting output), 369
serverStatus.metrics.repl.buffer.sizeBytes (MongoDB re-
porting output), 369
serverStatus.metrics.repl.network (MongoDB reporting
output), 369
serverStatus.metrics.repl.network.bytes (MongoDB re-
porting output), 369
serverStatus.metrics.repl.network.getmores (MongoDB
reporting output), 369
serverStatus.metrics.repl.network.getmores.num (Mon-
goDB reporting output), 369
serverStatus.metrics.repl.network.getmores.totalMillis
(MongoDB reporting output), 369
serverStatus.metrics.repl.network.ops (MongoDB report-
ing output), 369
serverStatus.metrics.repl.network.readersCreated (Mon-
goDB reporting output), 370
serverStatus.metrics.repl.oplog (MongoDB reporting out-
put), 370
serverStatus.metrics.repl.oplog.insert (MongoDB report-
ing output), 370
serverStatus.metrics.repl.oplog.insert.num (MongoDB
reporting output), 370
serverStatus.metrics.repl.oplog.insert.totalMillis (Mon-
goDB reporting output), 370
serverStatus.metrics.repl.oplog.insertBytes (MongoDB
reporting output), 370
serverStatus.metrics.repl.preload (MongoDB reporting
output), 370
serverStatus.metrics.repl.preload.docs (MongoDB report-
ing output), 370
serverStatus.metrics.repl.preload.docs.num (MongoDB
reporting output), 370
serverStatus.metrics.repl.preload.docs.totalMillis (Mon-
goDB reporting output), 370
serverStatus.metrics.repl.preload.indexes (MongoDB re-
porting output), 370
serverStatus.metrics.repl.preload.indexes.num (Mon-
goDB reporting output), 370
serverStatus.metrics.repl.preload.indexes.totalMillis
(MongoDB reporting output), 370
serverStatus.metrics.ttl (MongoDB reporting output), 370
serverStatus.metrics.ttl.deletedDocuments (MongoDB re-
porting output), 370
serverStatus.metrics.ttl.passes (MongoDB reporting out-
put), 371
serverStatus.network (MongoDB reporting output), 362
serverStatus.network.bytesIn (MongoDB reporting out-
put), 362
serverStatus.network.bytesOut (MongoDB reporting out-
put), 362
serverStatus.network.numRequests (MongoDB reporting
output), 362
serverStatus.opcounters (MongoDB reporting output),
363
serverStatus.opcounters.command (MongoDB reporting
output), 364
serverStatus.opcounters.delete (MongoDB reporting out-
put), 364
serverStatus.opcounters.getmore (MongoDB reporting
output), 364
serverStatus.opcounters.insert (MongoDB reporting out-
put), 363
serverStatus.opcounters.query (MongoDB reporting out-
put), 363
serverStatus.opcounters.update (MongoDB reporting out-
put), 364
Index 779
MongoDB Reference Manual, Release 2.6.4
serverStatus.opcountersRepl (MongoDB reporting out-
put), 363
serverStatus.opcountersRepl.command (MongoDB re-
porting output), 363
serverStatus.opcountersRepl.delete (MongoDB reporting
output), 363
serverStatus.opcountersRepl.getmore (MongoDB report-
ing output), 363
serverStatus.opcountersRepl.insert (MongoDB reporting
output), 363
serverStatus.opcountersRepl.query (MongoDB reporting
output), 363
serverStatus.opcountersRepl.update (MongoDBreporting
output), 363
serverStatus.process (MongoDB reporting output), 355
serverStatus.recordStats (MongoDB reporting output),
366
serverStatus.recordStats.<database>.accessesNotInMemory
(MongoDB reporting output), 366
serverStatus.recordStats.<database>.pageFaultExceptionsThrown
(MongoDB reporting output), 366
serverStatus.recordStats.accessesNotInMemory (Mon-
goDB reporting output), 366
serverStatus.recordStats.admin.accessesNotInMemory
(MongoDB reporting output), 366
serverStatus.recordStats.admin.pageFaultExceptionsThrown
(MongoDB reporting output), 366
serverStatus.recordStats.local.accessesNotInMemory
(MongoDB reporting output), 366
serverStatus.recordStats.local.pageFaultExceptionsThrown
(MongoDB reporting output), 366
serverStatus.recordStats.pageFaultExceptionsThrown
(MongoDB reporting output), 366
serverStatus.repl (MongoDB reporting output), 362
serverStatus.repl.hosts (MongoDB reporting output), 362
serverStatus.repl.ismaster (MongoDB reporting output),
362
serverStatus.repl.secondary (MongoDBreporting output),
362
serverStatus.repl.setName (MongoDB reporting output),
362
serverStatus.uptime (MongoDB reporting output), 355
serverStatus.uptimeEstimate (MongoDB reporting out-
put), 355
serverStatus.version (MongoDB reporting output), 355
serverStatus.workingSet (MongoDB reporting output),
367
serverStatus.workingSet.computationTimeMicros (Mon-
goDB reporting output), 367
serverStatus.workingSet.note (MongoDB reporting out-
put), 367
serverStatus.workingSet.overSeconds (MongoDB report-
ing output), 367
serverStatus.workingSet.pagesInMemory (MongoDB re-
porting output), 367
serverStatus.writeBacksQueued (MongoDB reporting
output), 364
set name, 671
setParameter (database command), 334
setShardVersion (database command), 306
sh._adminCommand (shell method), 181
sh._checkFullName (shell method), 181
sh._checkMongos (shell method), 181
sh._lastMigration (shell method), 181
sh._lastMigration._id (MongoDB reporting output), 181
sh._lastMigration.clientAddr (MongoDB reporting out-
put), 182
sh._lastMigration.details (MongoDB reporting output),
182
sh._lastMigration.ns (MongoDB reporting output), 182
sh._lastMigration.server (MongoDB reporting output),
181
sh._lastMigration.time (MongoDB reporting output), 182
sh._lastMigration.what (MongoDB reporting output), 182
sh.addShard (shell method), 182
sh.addShardTag (shell method), 183
sh.addTagRange (shell method), 183
sh.disableBalancing (shell method), 184
sh.enableBalancing (shell method), 184
sh.enableSharding (shell method), 185
sh.getBalancerHost (shell method), 185
sh.getBalancerState (shell method), 185
sh.help (shell method), 186
sh.isBalancerRunning (shell method), 186
sh.moveChunk (shell method), 186
sh.removeShardTag (shell method), 187
sh.setBalancerState (shell method), 187
sh.shardCollection (shell method), 188
sh.splitAt (shell method), 188
sh.splitFind (shell method), 189
sh.startBalancer (shell method), 189
sh.status (shell method), 189
sh.status.databases._id (MongoDB reporting output), 191
sh.status.databases.chunk-details (MongoDB reporting
output), 191
sh.status.databases.chunks (MongoDB reporting output),
191
sh.status.databases.partitioned (MongoDB reporting out-
put), 191
sh.status.databases.primary (MongoDB reporting output),
191
sh.status.databases.shard-key (MongoDB reporting out-
put), 191
sh.status.databases.tag (MongoDB reporting output), 191
sh.status.sharding-version._id (MongoDB reporting out-
put), 191
780 Index
MongoDB Reference Manual, Release 2.6.4
sh.status.sharding-version.clusterId (MongoDB reporting
output), 191
sh.status.sharding-version.currentVersion (MongoDB re-
porting output), 191
sh.status.sharding-version.minCompatibleVersion (Mon-
goDB reporting output), 191
sh.status.sharding-version.version (MongoDB reporting
output), 191
sh.status.shards._id (MongoDB reporting output), 191
sh.status.shards.host (MongoDB reporting output), 191
sh.status.shards.tags (MongoDB reporting output), 191
sh.stopBalancer (shell method), 192
sh.waitForBalancer (shell method), 192
sh.waitForBalancerOff (shell method), 192
sh.waitForDLock (shell method), 193
sh.waitForPingChange (shell method), 193
shard, 671
shard key, 671
Shard Key Index Type (MongoDB system limit), 661
Shard Key is Immutable (MongoDB system limit), 661
Shard Key Size (MongoDB system limit), 661
Shard Key Value in a Document is Immutable (MongoDB
system limit), 662
shardCollection (database command), 307
shardConnPoolStats (database command), 371
shardConnPoolStats.createdByType (MongoDB report-
ing output), 372
shardConnPoolStats.createdByType.master (MongoDB
reporting output), 372
shardConnPoolStats.createdByType.set (MongoDB re-
porting output), 372
shardConnPoolStats.createdByType.sync (MongoDB re-
porting output), 372
shardConnPoolStats.hosts (MongoDB reporting output),
372
shardConnPoolStats.hosts.<host>.available (MongoDB
reporting output), 372
shardConnPoolStats.hosts.<host>.created (MongoDB re-
porting output), 372
shardConnPoolStats.replicaSets (MongoDB reporting
output), 372
shardConnPoolStats.replicaSets.<name>.host (Mon-
goDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].addr
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].hidden
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].ismaster
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].ok
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].pingTimeMillis
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].secondary
(MongoDB reporting output), 372
shardConnPoolStats.replicaSets.<name>.host[n].tags
(MongoDB reporting output), 372
shardConnPoolStats.threads (MongoDB reporting out-
put), 372
shardConnPoolStats.threads.hosts (MongoDB reporting
output), 372
shardConnPoolStats.threads.hosts.avail (MongoDB re-
porting output), 373
shardConnPoolStats.threads.hosts.created (MongoDB re-
porting output), 373
shardConnPoolStats.threads.hosts.host (MongoDB re-
porting output), 373
shardConnPoolStats.threads.seenNS (MongoDB report-
ing output), 373
shardConnPoolStats.totalAvailable (MongoDB reporting
output), 372
shardConnPoolStats.totalCreated (MongoDB reporting
output), 372
sharded cluster, 671
sharding, 671
cong database, 647
Sharding Existing Collection Data Size (MongoDB sys-
tem limit), 661
shardingState (database command), 308
shell helper, 671
shutdown (database command), 334
Single Document Modication Operations in Sharded
Collections (MongoDB system limit), 661
single-master replication, 671
Size of Namespace File (MongoDB system limit), 658
slave, 671
sleep (database command), 384
Sorted Documents (MongoDB system limit), 662
Spherical Polygons must t within a hemisphere. (Mon-
goDB system limit), 662
split, 671
split (database command), 309
splitChunk (database command), 308
splitVector (database command), 309
SQL, 671
SSD, 671
stale, 671
standalone, 672
stopMongod (shell method), 195
stopMongoProgram (shell method), 195
stopMongoProgramByPid (shell method), 195
strict consistency, 672
sync, 672
syslog, 672
system
collections, 654
namespace, 654
Index 781
MongoDB Reference Manual, Release 2.6.4
system.indexes.key (MongoDB reporting output), 45
system.indexes.name (MongoDB reporting output), 45
system.indexes.ns (MongoDB reporting output), 45
system.indexes.v (MongoDB reporting output), 45
T
tag, 672
tailable cursor, 672
text (database command), 248
top (database command), 373
touch (database command), 335
TSV, 672
TTL, 672
U
unique index, 672
Unique Indexes in Sharded Collections (MongoDB sys-
tem limit), 661
unix epoch, 672
unordered query plan, 672
unsetSharding (database command), 311
update (database command), 249
update.n (MongoDB reporting output), 251
update.nModied (MongoDB reporting output), 252
update.ok (MongoDB reporting output), 251
update.upserted (MongoDB reporting output), 252
update.upserted._id (MongoDB reporting output), 252
update.upserted.index (MongoDB reporting output), 252
update.writeConcernError (MongoDB reporting output),
252
update.writeConcernError.code (MongoDB reporting
output), 252
update.writeConcernError.errmsg (MongoDB reporting
output), 252
update.writeErrors (MongoDB reporting output), 252
update.writeErrors.code (MongoDB reporting output),
252
update.writeErrors.errmsg (MongoDB reporting output),
252
update.writeErrors.index (MongoDB reporting output),
252
updateRole (database command), 284
updateUser (database command), 268
upsert, 672
usePowerOf2Sizes, 314
usePowerOf2Sizes (collection ag), 314
usersInfo (database command), 270
UUID (shell method), 198
V
validate (database command), 374
validate.bytesWithHeaders (MongoDB reporting output),
376
validate.bytesWithoutHeaders (MongoDB reporting out-
put), 376
validate.datasize (MongoDB reporting output), 375
validate.deletedCount (MongoDB reporting output), 376
validate.deletedSize (MongoDB reporting output), 376
validate.errors (MongoDB reporting output), 377
validate.extentCount (MongoDB reporting output), 375
validate.extents (MongoDB reporting output), 375
validate.extents.rstRecord (MongoDB reporting output),
375
validate.extents.lastRecord (MongoDB reporting output),
375
validate.extents.loc (MongoDB reporting output), 375
validate.extents.nsdiag (MongoDB reporting output), 375
validate.extents.size (MongoDB reporting output), 375
validate.extents.xnext (MongoDB reporting output), 375
validate.extents.xprev (MongoDB reporting output), 375
validate.rstExtent (MongoDB reporting output), 375
validate.rstExtentDetails (MongoDB reporting output),
376
validate.rstExtentDetails.rstRecord (MongoDB report-
ing output), 376
validate.rstExtentDetails.lastRecord (MongoDB report-
ing output), 376
validate.rstExtentDetails.loc (MongoDB reporting out-
put), 376
validate.rstExtentDetails.nsdiag (MongoDB reporting
output), 376
validate.rstExtentDetails.size (MongoDB reporting out-
put), 376
validate.rstExtentDetails.xnext (MongoDB reporting
output), 376
validate.rstExtentDetails.xprev (MongoDB reporting
output), 376
validate.invalidObjects (MongoDB reporting output), 376
validate.keysPerIndex (MongoDB reporting output), 377
validate.lastExtent (MongoDB reporting output), 375
validate.lastExtentSize (MongoDB reporting output), 375
validate.nIndexes (MongoDB reporting output), 377
validate.nrecords (MongoDB reporting output), 375
validate.ns (MongoDB reporting output), 375
validate.objectsFound (MongoDB reporting output), 376
validate.ok (MongoDB reporting output), 377
validate.padding (MongoDB reporting output), 375
validate.valid (MongoDB reporting output), 377
version (shell method), 208
virtual memory, 672
W
waitMongoProgramOnPort (shell method), 195
waitProgram (shell method), 195
WGS84, 672
whatsmyuri (database command), 377
working set, 672
782 Index
MongoDB Reference Manual, Release 2.6.4
Write Command Operation Limit Size (MongoDB system
limit), 663
write concern, 672
write lock, 673
writebacklisten (database command), 380
writeBacks, 673
writeBacksQueued (database command), 379
writeBacksQueued.hasOpsQueued (MongoDB reporting
output), 379
writeBacksQueued.queues (MongoDB reporting output),
379
writeBacksQueued.queues.minutesSinceLastCall (Mon-
goDB reporting output), 379
writeBacksQueued.queues.n (MongoDB reporting out-
put), 379
writeBacksQueued.totalOpsQueued (MongoDB report-
ing output), 379
WriteResult (shell method), 198
WriteResult._id (MongoDB reporting output), 199
WriteResult.hasWriteConcernError (shell method), 199
WriteResult.hasWriteError (shell method), 200
WriteResult.nInserted (MongoDB reporting output), 199
WriteResult.nMatched (MongoDB reporting output), 199
WriteResult.nModied (MongoDB reporting output), 199
WriteResult.nRemoved (MongoDB reporting output),
199
WriteResult.nUpserted (MongoDB reporting output), 199
WriteResult.writeConcernError (MongoDB reporting
output), 199
WriteResult.writeConcernError.code (MongoDB report-
ing output), 199
WriteResult.writeConcernError.errInfo (MongoDB re-
porting output), 199
WriteResult.writeError (MongoDB reporting output), 199
WriteResult.writeError.code (MongoDB reporting out-
put), 199
WriteResult.writeError.errmsg (MongoDB reporting out-
put), 199
Index 783

You might also like