Supported MongoDB APIs, Operations, and Data Types - Amazon DocumentDB
Services or capabilities described in Amazon Web Services documentation might vary by Region. To see the differences applicable to the China Regions, see Getting Started with Amazon Web Services in China (PDF).

Supported MongoDB APIs, Operations, and Data Types

Amazon DocumentDB (with MongoDB compatibility) is a fast, scalable, highly-available, and fully managed document database service that supports MongoDB workloads. Amazon DocumentDB is compatible with the MongoDB 3.6, 4.0, and 5.0 APIs. This section lists the supported functionality. For support using MongoDB APIs and drivers, please consult the MongoDB Community Forums. For support using the Amazon DocumentDB service, please contact the appropriate Amazon support team. For functional differences between Amazon DocumentDB and MongoDB, please see Functional Differences: Amazon DocumentDB and MongoDB.

MongoDB commands and operators that are internal-only or not applicable to a fully-managed service are not supported and are not included in the list of supported functionality.

We have added over 50+ additional capabilities since launch, and will continue to work backwards from our customers to deliver the capabilities that they need. For information on the most recent launches, see Amazon DocumentDB Announcements.

If there is a feature that isn't supported that you'd like us to build, let us know by sending an email with your accountID, the requested features, and use case to the Amazon DocumentDB service team.

Database Commands

Administrative Commands

Command 3.6 4.0 5.0 Elastic cluster

Capped Collections

No

No

No

No

cloneCollectionAsCapped

No

No

No

No

collMod

Partial

Partial

Partial

Yes

collMod: expireAfterSeconds

Yes

Yes

Yes

No

convertToCapped

No

No

No

No

copydb

No

No

No

No

create

Yes

Yes

Yes

Yes

createView

No

No

No

No

createIndexes

Yes

Yes

Yes

Yes

currentOp

Yes

Yes

Yes

Yes

drop

Yes

Yes

Yes

Yes

dropDatabase

Yes

Yes

Yes

Yes

dropIndexes

Yes

Yes

Yes

Yes

filemd5

No

No

No

No

killCursors

Yes

Yes

Yes

Yes

killOp

Yes

Yes

Yes

Yes

listCollections*

Yes

Yes

Yes

Yes

listDatabases

Yes

Yes

Yes

Yes

listIndexes

Yes

Yes

Yes

Yes

reIndex

No

No

No

No

renameCollection

Yes

Yes

Yes

No

* The type key in the filter option is not supported.

Aggregation

Command 3.6 4.0 5.0 Elastic cluster

aggregate

Yes

Yes

Yes

Yes

count

Yes

Yes

Yes

Yes

distinct

Yes

Yes

Yes

Yes

mapReduce

No

No

No

No

Authentication

Command 3.6 4.0 5.0 Elastic cluster

authenticate

Yes

Yes

Yes

Yes

logout

Yes

Yes

Yes

Yes

Diagnostic Commands

Command 3.6 4.0 5.0 Elastic cluster

buildInfo

Yes

Yes

Yes

Yes

collStats

Yes

Yes

Yes

Yes

connPoolStats

No

No

No

No

connectionStatus

Yes

Yes

Yes

Yes

dataSize

Yes

Yes

Yes

Yes

dbHash

No

No

No

No

dbStats

Yes

Yes

Yes

Yes

explain

Yes

Yes

Yes

Yes

explain: executionStats

Yes

Yes

Yes

Yes

features

No

No

No

No

hostInfo

Yes

Yes

Yes

Yes

listCommands

Yes

Yes

Yes

Yes

profiler

Yes

Yes

Yes

No

serverStatus

Yes

Yes

Yes

Yes

top

Yes

Yes

Yes

Yes

Query and Write Operations

Command 3.6 4.0 5.0 Elastic cluster

delete

Yes

Yes

Yes

Yes

find

Yes

Yes

Yes

Yes

findAndModify

Yes

Yes

Yes

Yes

getLastError

No

No

No

No

getMore

Yes

Yes

Yes

Yes

getPrevError

No

No

No

No

insert

Yes

Yes

Yes

Yes

parallelCollectionScan

No

No

No

No

resetError

No

No

No

No

update

Yes

Yes

Yes

Yes

Change streams

Yes

Yes

Yes

No

GridFS

No

No

No

No

ReplaceOne

Yes

Yes

Yes

Yes

Role Management Commands

Command 3.6 4.0 5.0 Elastic cluster

createRole

Yes

Yes

Yes

No

dropRole

Yes

Yes

Yes

No

dropAllRolesFromDatabase

Yes

Yes

Yes

No

grantRolesToRole

Yes

Yes

Yes

No

revokePrivilegesFromRole

Yes

Yes

Yes

No

revokeRolesFromRole

Yes

Yes

Yes

No

updateRole

Yes

Yes

Yes

No

rolesInfo

Yes

Yes

Yes

No

Sessions Commands

Command 3.6 4.0 5.0 Elastic cluster

abortTransaction

No

Yes

Yes

No

commitTransaction

No

Yes

Yes

No

endSessions

No

No

No

No

killAllSessions

No

Yes

Yes

No

killAllSessionsByPattern

No

No

No

No

killSessions

No

Yes

Yes

No

refreshSessions

No

No

No

No

startSession

No

Yes

Yes

No

User Management

Command 3.6 4.0 5.0 Elastic cluster

createUser

Yes

Yes

Yes

Yes

dropAllUsersFromDatabase

Yes

Yes

Yes

Yes

dropUser

Yes

Yes

Yes

Yes

grantRolesToUser

Yes

Yes

Yes

Yes

revokeRolesFromUser

Yes

Yes

Yes

Yes

updateUser

Yes

Yes

Yes

Yes

userInfo

Yes

Yes

Yes

Yes

Sharding Commands

Command Elastic cluster

abortReshardCollection

No

addShard

No

addShardToZone

No

balancerCollectionStatus

No

balancerStart

No

balancerStatus

No

balancerStop

No

checkShardingIndex

No

clearJumboFlag

No

cleanupOrphaned

No

cleanupReshardCollection

No

commitReshardCollection

No

enableSharding

Yes

flushRouterConfig

No

getShardMap

No

getShardVersion

No

isdbgrid

No

listShards

No

medianKey

No

moveChunk

No

movePrimary

No

mergeChunks

No

refineCollectionShardKey

No

removeShard

No

removeShardFromZone

No

reshardCollection

No

setAllowMigrations

No

setShardVersion

No

shardCollection

Yes

shardingState

No

split

No

splitVector

No

unsetSharding

No

updateZoneKeyRange

No

Query and Projection Operators

Array Operators

Command 3.6 4.0 5.0 Elastic cluster

$all

Yes

Yes

Yes

Yes

$elemMatch

Yes

Yes

Yes

Yes

$size

Yes

Yes

Yes

Yes

Bitwise Operators

Command 3.6 4.0 5.0 Elastic cluster

$bitsAllSet

Yes

Yes

Yes

Yes

$bitsAnySet

Yes

Yes

Yes

Yes

$bitsAllClear

Yes

Yes

Yes

Yes

$bitsAnyClear

Yes

Yes

Yes

Yes

Comment Operator

Command 3.6 4.0 5.0 Elastic cluster

$comment

Yes

Yes

Yes

Yes

Comparison Operators

Command 3.6 4.0 5.0 Elastic cluster

$eq

Yes

Yes

Yes

Yes

$gt

Yes

Yes

Yes

Yes

$gte

Yes

Yes

Yes

Yes

$lt

Yes

Yes

Yes

Yes

$lte

Yes

Yes

Yes

Yes

$ne

Yes

Yes

Yes

Yes

$in

Yes

Yes

Yes

Yes

$nin

Yes

Yes

Yes

Yes

Element Operators

Command 3.6 4.0 5.0 Elastic cluster

$exists

Yes

Yes

Yes

Yes

$type

Yes

Yes

Yes

Yes

Evaluation Query Operators

Command 3.6 4.0 5.0 Elastic cluster

$expr

No

No

No

No

$jsonSchema

No

Yes

Yes

No

$mod

Yes

Yes

Yes

Yes

$regex

Yes

Yes

Yes

Yes

$text

No

No

Yes

No

$where

No

No

No

No

Logical Operators

Command 3.6 4.0 5.0 Elastic cluster

$or

Yes

Yes

Yes

Yes

$and

Yes

Yes

Yes

Yes

$not

Yes

Yes

Yes

Yes

$nor

Yes

Yes

Yes

Yes

Projection Operators

Command 3.6 4.0 5.0 Elastic cluster

$

Yes

Yes

Yes

Yes

$elemMatch

Yes

Yes

Yes

Yes

$meta

No

No

Yes

No

$slice

Yes

Yes

Yes

Yes

Update Operators

Array Operators

Command 3.6 4.0 5.0 Elastic cluster

$

Yes

Yes

Yes

Yes

$[]

Yes

Yes

Yes

Yes

$[<identifier>]

Yes

Yes

Yes

Yes

$addToSet

Yes

Yes

Yes

Yes

$pop

Yes

Yes

Yes

Yes

$pullAll

Yes

Yes

Yes

Yes

$pull

Yes

Yes

Yes

Yes

$push

Yes

Yes

Yes

Yes

Bitwise Operators

Command 3.6 4.0 5.0 Elastic cluster

$bit

Yes

Yes

Yes

Yes

Field Operators

Operator 3.6 4.0 5.0 Elastic cluster

$inc

Yes

Yes

Yes

Yes

$mul

Yes

Yes

Yes

Yes

$rename

Yes

Yes

Yes

Yes

$setOnInsert

Yes

Yes

Yes

Yes

$set

Yes

Yes

Yes

Yes

$unset

Yes

Yes

Yes

Yes

$min

Yes

Yes

Yes

Yes

$max

Yes

Yes

Yes

Yes

$currentDate

Yes

Yes

Yes

Yes

Update Modifiers

Operator 3.6 4.0 5.0 Elastic cluster

$each

Yes

Yes

Yes

Yes

$slice

Yes

Yes

Yes

Yes

$sort

Yes

Yes

Yes

Yes

$position

Yes

Yes

Yes

Yes

Geospatial

Geometry Specifiers

Query Selectors 3.6 4.0 5.0 Elastic cluster

$box

No

No

No

No

$center

No

No

No

No

$centerSphere

No

No

No

No

$nearSphere

Yes

Yes

Yes

No

$geometry

Yes

Yes

Yes

No

$maxDistance

Yes

Yes

Yes

No

$minDistance

Yes

Yes

Yes

No

$polygon

No

No

No

No

$uniqueDocs

No

No

No

No

Query Selectors

Command 3.6 4.0 5.0 Elastic cluster

$geoIntersects

Yes

Yes

Yes

No

$geoWithin

Yes

Yes

Yes

No

$near

No

No

No

No

$nearSphere

Yes

Yes

Yes

No

$polygon

No

No

No

No

$uniqueDocs

No

No

No

No

Cursor Methods

Command 3.6 4.0 5.0 Elastic cluster

cursor.batchSize()

Yes

Yes

Yes

Yes

cursor.close()

Yes

Yes

Yes

Yes

cursor.isClosed()

Yes

Yes

Yes

Yes

cursor.collation()

No

No

No

No

cursor.comment()

Yes

Yes

Yes

Yes

cursor.count()

Yes

Yes

Yes

Yes

cursor.explain()

Yes

Yes

Yes

No

cursor.forEach()

Yes

Yes

Yes

Yes

cursor.hasNext()

Yes

Yes

Yes

Yes

cursor.hint()

Yes

Yes

Yes

Yes*

cursor.isExhausted()

Yes

Yes

Yes

No

cursor.itcount()

Yes

Yes

Yes

No

cursor.limit()

Yes

Yes

Yes

No

cursor.map()

Yes

Yes

Yes

No

cursor.maxScan()

Yes

Yes

Yes

No

cursor.maxTimeMS()

Yes

Yes

Yes

No

cursor.max()

No

No

No

No

cursor.min()

No

No

No

No

cursor.next()

Yes

Yes

Yes

Yes

cursor.noCursorTimeout()

No

No

No

No

cursor.objsLeftInBatch()

Yes

Yes

Yes

No

cursor.pretty()

Yes

Yes

Yes

No

cursor.readConcern()

Yes

Yes

Yes

No

cursor.readPref()

Yes

Yes

Yes

No

cursor.returnKey()

No

No

No

No

cursor.showRecordId()

No

No

No

No

cursor.size()

Yes

Yes

Yes

No

cursor.skip()

Yes

Yes

Yes

No

cursor.sort()

Yes

Yes

Yes

No

cursor.tailable()

No

No

No

No

cursor.toArray()

Yes

Yes

Yes

No

* Index hint is supported with index expressions. For example, db.foo.find().hint({x:1}).

Aggregation Pipeline Operators

Accumulator Expressions

Expression 3.6 4.0 5.0 Elastic cluster

$sum

Yes

Yes

Yes

Yes

$avg

Yes

Yes

Yes

Yes

$first

Yes

Yes

Yes

Yes

$last

Yes

Yes

Yes

Yes

$max

Yes

Yes

Yes

Yes

$min

Yes

Yes

Yes

Yes

$push

Yes

Yes

Yes

Yes

$addToSet

Yes

Yes

Yes

Yes

$stdDevPop

No

No

No

Yes

$stdDevSamp

No

No

No

Yes

$accumulator

-

-

No

No

$count

-

-

No

No

Arithmetic Operators

Command 3.6 4.0 5.0 Elastic cluster

$abs

Yes

Yes

Yes

Yes

$add

Yes

Yes

Yes

Yes

$ceil

No

Yes

Yes

No

$divide

Yes

Yes

Yes

Yes

$exp

No

Yes

Yes

No

$floor

No

Yes

Yes

No

$ln

No

Yes

Yes

No

$log

No

Yes

Yes

No

$log10

No

Yes

Yes

No

$mod

Yes

Yes

Yes

Yes

$multiply

Yes

Yes

Yes

Yes

$pow

No

No

No

No

$sqrt

No

Yes

Yes

No

$subtract

Yes

Yes

Yes

Yes

$trunc

No

No

No

No

$round

-

-

No

No

Array Operators

Command 3.6 4.0 5.0 Elastic cluster

$arrayElemAt

Yes

Yes

Yes

Yes

$arrayToObject

Yes

Yes

Yes

Yes

$concatArrays

Yes

Yes

Yes

Yes

$filter

Yes

Yes

Yes

Yes

$indexOfArray

Yes

Yes

Yes

Yes

$isArray

Yes

Yes

Yes

Yes

$objectToArray

Yes

Yes

Yes

Yes

$range

Yes

Yes

Yes

Yes

$reverseArray

Yes

Yes

Yes

Yes

$reduce

Yes

Yes

Yes

Yes

$size

Yes

Yes

Yes

Yes

$slice

Yes

Yes

Yes

Yes

$zip

Yes

Yes

Yes

Yes

$in

Yes

Yes

Yes

Yes

$first

-

-

No

No

$last

-

-

No

No

Boolean Operators

Command 3.6 4.0 5.0 Elastic cluster

$and

Yes

Yes

Yes

Yes

$or

Yes

Yes

Yes

Yes

$not

Yes

Yes

Yes

Yes

Comparison Operators

Command 3.6 4.0 5.0 Elastic cluster

$cmp

Yes

Yes

Yes

Yes

$eq

Yes

Yes

Yes

Yes

$gt

Yes

Yes

Yes

Yes

$gte

Yes

Yes

Yes

Yes

$lt

Yes

Yes

Yes

Yes

$lte

Yes

Yes

Yes

Yes

$ne

Yes

Yes

Yes

Yes

Conditional Expression Operators

Command 3.6 4.0 5.0 Elastic cluster

$cond

Yes

Yes

Yes

Yes

$ifNull

Yes

Yes

Yes

Yes

$switch

No

No

No

No

Data Type Operator

Command 3.6 4.0 5.0 Elastic cluster

$type

Yes

Yes

Yes

Yes

Data Size Operator

Command 3.6 4.0 5.0 Elastic cluster

$binarySize

-

-

No

No

$bsonSize

-

-

No

No

Date Operators

Command 3.6 4.0 5.0 Elastic cluster

$dateAdd

No

No

Yes

Yes

$dateSubtract

No

No

Yes

Yes

$dayOfYear

Yes

Yes

Yes

Yes

$dayOfMonth

Yes

Yes

Yes

Yes

$dayOfWeek

Yes

Yes

Yes

Yes

$year

Yes

Yes

Yes

Yes

$month

Yes

Yes

Yes

Yes

$week

Yes

Yes

Yes

Yes

$hour

Yes

Yes

Yes

Yes

$minute

Yes

Yes

Yes

Yes

$second

Yes

Yes

Yes

Yes

$millisecond

Yes

Yes

Yes

Yes

$dateToString

Yes

Yes

Yes

Yes

$isoDayOfWeek

Yes

Yes

Yes

Yes

$isoWeek

Yes

Yes

Yes

Yes

$dateFromParts

No

No

No

No

$dateToParts

No

No

No

No

$dateFromString

Yes

Yes

Yes

Yes

$isoWeekYear

Yes

Yes

Yes

Yes

$dataTrunc

-

-

No

No

$dataDiff

-

-

No

No

Literal Operator

Command 3.6 4.0 5.0 Elastic cluster

$literal

Yes

Yes

Yes

Yes

Merge Operator

Command 3.6 4.0 5.0 Elastic cluster

$mergeObjects

Yes

Yes

Yes

Yes

Natural Operator

Command 3.6 4.0 5.0 Elastic cluster

$natural

Yes

Yes

Yes

Yes

Set Operators

Command 3.6 4.0 5.0 Elastic cluster

$setEquals

Yes

Yes

Yes

Yes

$setIntersection

Yes

Yes

Yes

Yes

$setUnion

Yes

Yes

Yes

Yes

$setDifference

No

Yes

Yes

Yes

$setIsSubset

Yes

Yes

Yes

Yes

$anyElementTrue

No

Yes

Yes

Yes

$allElementsTrue

No

Yes

Yes

Yes

Stage Operators

Command 3.6 4.0 5.0 Elastic cluster

$collStats

No

No

No

No

$project

Yes

Yes

Yes

Yes

$match

Yes

Yes

Yes

Yes

$redact

Yes

Yes

Yes

Yes

$limit

Yes

Yes

Yes

Yes

$skip

Yes

Yes

Yes

Yes

$unwind

Yes

Yes

Yes

Yes

$group

Yes

Yes

Yes

Yes

$sample

Yes

Yes

Yes

No

$sort

Yes

Yes

Yes

Yes

$geoNear

Yes

Yes

Yes

No

$lookup

Yes

Yes

Yes

Yes

$out

Yes

Yes

Yes

No

$indexStats

Yes

Yes

Yes

Yes

$facet

No

No

No

No

$bucket

No

No

No

No

$bucketAuto

No

No

No

No

$sortByCount

No

No

No

No

$addFields

Yes

Yes

Yes

Yes

$replaceRoot

Yes

Yes

Yes

Yes

$count

Yes

Yes

Yes

Yes

$currentOp

Yes

Yes

Yes

No

$listLocalSessions

No

No

No

No

$listSessions

No

No

No

No

$graphLookup

No

No

No

No

$merge

-

-

No

No

$planCacheStats

-

-

No

No

$setWindowFields

-

-

No

No

$unionWith

-

-

No

No

$unset

-

-

No

No

String Operators

Command 3.6 4.0 5.0 Elastic cluster

$concat

Yes

Yes

Yes

Yes

$indexOfBytes

Yes

Yes

Yes

Yes

$indexOfCP

Yes

Yes

Yes

Yes

$ltrim

No

No

No

No

$rtrim

No

No

No

No

$split

Yes

Yes

Yes

Yes

$strcasecmp

Yes

Yes

Yes

Yes

$strLenBytes

Yes

Yes

Yes

Yes

$strLenCP

Yes

Yes

Yes

Yes

$substr

Yes

Yes

Yes

Yes

$substrBytes

Yes

Yes

Yes

Yes

$substrCP

Yes

Yes

Yes

Yes

$toLower

Yes

Yes

Yes

Yes

$toUpper

Yes

Yes

Yes

Yes

$trim

No

No

No

No

$regxFind

-

-

No

No

$regexFindAll

-

-

No

No

$regexMatch

-

-

No

No

$replaceOne

-

-

No

No

$replaceAll

-

-

No

No

System Variables

Command 3.6 4.0 5.0 Elastic cluster

$$CURRENT

No

No

No

No

$$DESCEND

Yes

Yes

Yes

Yes

$$KEEP

Yes

Yes

Yes

Yes

$$PRUNE

Yes

Yes

Yes

Yes

$$REMOVE

No

No

No

No

$$ROOT

Yes

Yes

Yes

Yes

Command 3.6 4.0 5.0 Elastic cluster

$search

No

No

Yes

No

$meta

No

No

Yes

No

Type Conversion Operators

Command 3.6 4.0 5.0 Elastic cluster

$convert

No

Yes

Yes

Yes

$toBool

No

Yes

Yes

Yes

$toDate

No

Yes

Yes

Yes

$toDecimal

No

Yes

Yes

Yes

$toDouble

No

Yes

Yes

Yes

$toInt

No

Yes

Yes

Yes

$toLong

No

Yes

Yes

Yes

$toObjectId

No

Yes

Yes

Yes

$toString

No

Yes

Yes

Yes

$isNumber

-

-

No

No

Variable Operators

Command 3.6 4.0 5.0 Elastic cluster

$map

Yes

Yes

Yes

Yes

$let

Yes

Yes

Yes

Yes

Miscellaneous Operators

Command 3.6 4.0 5.0 Elastic cluster

$rand

-

-

No

No

$sampleRate

-

-

No

No

$getField

-

-

No

No

Data Types

Command 3.6 4.0 5.0 Elastic cluster

Double

Yes

Yes

Yes

Yes

String

Yes

Yes

Yes

Yes

Object

Yes

Yes

Yes

Yes

Array

Yes

Yes

Yes

Yes

Binary Data

Yes

Yes

Yes

Yes

ObjectId

Yes

Yes

Yes

Yes

Boolean

Yes

Yes

Yes

Yes

Date

Yes

Yes

Yes

Yes

Null

Yes

Yes

Yes

Yes

32-bit Integer (int)

Yes

Yes

Yes

Yes

Timestamp

Yes

Yes

Yes

Yes

64-bit Integer (long)

Yes

Yes

Yes

Yes

MinKey

Yes

Yes

Yes

Yes

MaxKey

Yes

Yes

Yes

Yes

Decimal128

Yes

Yes

Yes

Yes

Regular Expression

Yes

Yes

Yes

Yes

JavaScript

No

No

No

No

JavaScript (with scope)

No

No

No

No

Undefined

No

No

No

No

Symbol

No

No

No

No

DBPointer

No

No

No

No

Indexes and Index Properties

Indexes

Command 3.6 4.0 5.0 Elastic cluster

Single Field Index

Yes

Yes

Yes

Yes

Compound Index

Yes

Yes

Yes

Yes

Multikey Index

Yes

Yes

Yes

Yes

Text Index

No

No

Yes

No

2dsphere

Yes

Yes

Yes

No

2d Index

No

No

No

No

Hashed Index

No

No

No

No

Index Properties

Command 3.6 4.0 5.0 Elastic cluster

TTL

Yes

Yes

Yes

Yes

Unique

Yes

Yes

Yes

Yes

Partial

No

No

Yes

No

Case Insensitive

No

No

No

No

Sparse

Yes

Yes

Yes

Yes

Background

Yes

Yes

Yes

No