MongoDB
MongoDB support​
TypeORM has basic MongoDB support. Most of TypeORM functionality is RDBMS-specific, this page contains all MongoDB-specific functionality documentation.
Defining entities and columns​
Defining entities and columns is almost the same as in relational databases,
the main difference is that you must use @ObjectIdColumn
instead of @PrimaryColumn or @PrimaryGeneratedColumn.
Simple entity example:
import { Entity, ObjectId, ObjectIdColumn, Column } from "typeorm"
@Entity()
export class User {
@ObjectIdColumn()
_id: ObjectId
@Column()
firstName: string
@Column()
lastName: string
}
And this is how you bootstrap the app:
import { DataSource } from "typeorm"
const myDataSource = new DataSource({
type: "mongodb",
host: "localhost",
port: 27017,
database: "test",
})
Defining subdocuments (embed documents)​
Since MongoDB stores objects and objects inside objects (or documents inside documents) you can do the same in TypeORM:
import { Entity, ObjectId, ObjectIdColumn, Column } from "typeorm"
export class Profile {
@Column()
about: string
@Column()
education: string
@Column()
career: string
}
import { Entity, ObjectId, ObjectIdColumn, Column } from "typeorm"
export class Photo {
@Column()
url: string
@Column()
description: string
@Column()
size: number
constructor(url: string, description: string, size: number) {
this.url = url
this.description = description
this.size = size
}
}
import { Entity, ObjectId, ObjectIdColumn, Column } from "typeorm"
@Entity()
export class User {
@ObjectIdColumn()
id: ObjectId
@Column()
firstName: string
@Column()
lastName: string
@Column((type) => Profile)
profile: Profile
@Column((type) => Photo)
photos: Photo[]
}
If you save this entity:
import { getMongoManager } from "typeorm"
const user = new User()
user.firstName = "Timber"
user.lastName = "Saw"
user.profile = new Profile()
user.profile.about = "About Trees and Me"
user.profile.education = "Tree School"
user.profile.career = "Lumberjack"
user.photos = [
new Photo("me-and-trees.jpg", "Me and Trees", 100),
new Photo("me-and-chakram.jpg", "Me and Chakram", 200),
]
const manager = getMongoManager()
await manager.save(user)
Following document will be saved in the database:
{
"firstName": "Timber",
"lastName": "Saw",
"profile": {
"about": "About Trees and Me",
"education": "Tree School",
"career": "Lumberjack"
},
"photos": [
{
"url": "me-and-trees.jpg",
"description": "Me and Trees",
"size": 100
},
{
"url": "me-and-chakram.jpg",
"description": "Me and Chakram",
"size": 200
}
]
}
Using MongoEntityManager and MongoRepository​
You can use the majority of methods inside the EntityManager (except for RDBMS-specific, like query and transaction).
For example:
const timber = await myDataSource.manager.findOneBy(User, {
firstName: "Timber",
lastName: "Saw",
})
For MongoDB there is also a separate MongoEntityManager which extends EntityManager.
const timber = await myDataSource.manager.findOneBy(User, {
firstName: "Timber",
lastName: "Saw",
})
Just like separate like MongoEntityManager there is a MongoRepository with extended Repository:
const timber = await myDataSource.getMongoRepository(User).findOneBy({
firstName: "Timber",
lastName: "Saw",
})
Use Advanced options in find():
Equal:
const timber = await myDataSource.getMongoRepository(User).find({
where: {
firstName: { $eq: "Timber" },
},
})
LessThan:
const timber = await myDataSource.getMongoRepository(User).find({
where: {
age: { $lt: 60 },
},
})
In:
const timber = await myDataSource.getMongoRepository(User).find({
where: {
firstName: { $in: ["Timber", "Zhang"] },
},
})
Not in:
const timber = await myDataSource.getMongoRepository(User).find({
where: {
firstName: { $not: { $in: ["Timber", "Zhang"] } },
},
})
Or:
const timber = await myDataSource.getMongoRepository(User).find({
where: {
$or: [{ firstName: "Timber" }, { firstName: "Zhang" }],
},
})
Querying subdocuments
const users = await myDataSource.getMongoRepository(User).find({
where: {
"profile.education": { $eq: "Tree School" },
},
})
Querying Array of subdocuments
// Query users with photos of size less than 500
const users = await myDataSource.getMongoRepository(User).find({
where: {
"photos.size": { $lt: 500 },
},
})
Both MongoEntityManager and MongoRepository contain lot of useful MongoDB-specific methods:
createCursor​
Creates a cursor for a query that can be used to iterate over results from MongoDB.
createEntityCursor​
Creates a cursor for a query that can be used to iterate over results from MongoDB. This returns a modified version of the cursor that transforms each result into Entity models.
aggregate​
Execute an aggregation framework pipeline against the collection.
bulkWrite​
Perform a bulkWrite operation without a fluent API.
count​
Count number of matching documents in the db to a query.
countDocuments​
Count number of matching documents in the db to a query.
createCollectionIndex​
Creates an index on the db and collection.
createCollectionIndexes​
Creates multiple indexes in the collection, this method is only supported in MongoDB 2.6 or higher. Earlier version of MongoDB will throw a command not supported error. Index specifications are defined at http://docs.mongodb.org/manual/reference/command/createIndexes/.
deleteMany​
Delete multiple documents on MongoDB.
deleteOne​
Delete a document on MongoDB.
distinct​
The distinct command returns a list of distinct values for the given key across a collection.
dropCollectionIndex​
Drops an index from this collection.
dropCollectionIndexes​
Drops all indexes from the collection.
findOneAndDelete​
Find a document and delete it in one atomic operation, requires a write lock for the duration of the operation.
findOneAndReplace​
Find a document and replace it in one atomic operation, requires a write lock for the duration of the operation.
findOneAndUpdate​
Find a document and update it in one atomic operation, requires a write lock for the duration of the operation.
geoHaystackSearch​
Execute a geo search using a geo haystack index on a collection.
geoNear​
Execute the geoNear command to search for items in the collection.
group​
Run a group command across a collection.
collectionIndexes​
Retrieve all the indexes on the collection.
collectionIndexExists​
Retrieve if an index exists on the collection
collectionIndexInformation​
Retrieves this collections index info.
initializeOrderedBulkOp​
Initiate an In order bulk write operation, operations will be serially executed in the order they are added, creating a new operation for each switch in types.
initializeUnorderedBulkOp​
Initiate a Out of order batch write operation. All operations will be buffered into insert/update/remove commands executed out of order.
insertMany​
Inserts an array of documents into MongoDB.
insertOne​
Inserts a single document into MongoDB.
isCapped​
Returns if the collection is a capped collection.
listCollectionIndexes​
Get the list of all indexes information for the collection.
parallelCollectionScan​
Return N number of parallel cursors for a collection allowing parallel reading of entire collection. There are no ordering guarantees for returned results
reIndex​
Reindex all indexes on the collection Warning: reIndex is a blocking operation (indexes are rebuilt in the foreground) and will be slow for large collections.
rename​
Changes the name of an existing collection.
replaceOne​
Replace a document on MongoDB.
stats​
Get all the collection statistics.
updateMany​
Updates multiple documents within the collection based on the filter.
updateOne​
Updates a single document within the collection based on the filter.