
insert()方法向集合中插入文档,语法如下;db.collection.insert(document)insert()方法来插入文档,例如插入一个article文档;db.article.insert({title: 'MongoDB 教程',
description: 'MongoDB 是一个 Nosql 数据库',
by: 'Andy',
url: 'https://www.mongodb.com/',
tags: ['mongodb', 'database', 'NoSQL'],
likes: 100
})find()方法可以获取文档,例如获取所有的article文档;db.article.find({})
{
"_id" : ObjectId("5e9943661379a112845e4056"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Andy",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100.0
}update()来更新集合中的文档,语法如下;db.collection.update(
<query>,
<update>,
{
multi: <boolean>
}
)
# query:修改的查询条件,类似于SQL中的WHERE部分
# update:更新属性的操作符,类似SQL中的SET部分
# multi:设置为true时会更新所有符合条件的文档,默认为false只更新找到的第一条MongoDB 教程的所有文档的title修改为MongoDB;db.article.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})update()方法以外,save()方法可以用来替换已有文档,语法如下;db.collection.save(document)5e9943661379a112845e4056的文档的title改为MongoDB 教程;db.article.save({
"_id" : ObjectId("5e9943661379a112845e4056"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Andy",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100.0
})remove()方法来删除集合中的文档,语法如下;db.collection.remove(
<query>,
{
justOne: <boolean>
}
)
# query:删除的查询条件,类似于SQL中的WHERE部分
# justOne:设置为true只删除一条记录,默认为false删除所有记录MongoDB 教程的所有文档;db.article.remove({'title':'MongoDB 教程'})find()方法来查询文档,语法如下;db.collection.find(query, projection)
# query:查询条件,类似于SQL中的WHERE部分
# projection:可选,使用投影操作符指定返回的键article集合中的所有文档;db.article.find()
/* 1 */
{
"_id" : ObjectId("5e994dcb1379a112845e4057"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Andy",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 50.0
}
/* 2 */
{
"_id" : ObjectId("5e994df51379a112845e4058"),
"title" : "Elasticsearch 教程",
"description" : "Elasticsearch 是一个搜索引擎",
"by" : "Ruby",
"url" : "https://www.elastic.co/cn/",
"tags" : [
"elasticearch",
"database",
"NoSQL"
],
"likes" : 100.0
}
/* 3 */
{
"_id" : ObjectId("5e994e111379a112845e4059"),
"title" : "Redis 教程",
"description" : "Redis 是一个key-value数据库",
"by" : "Andy",
"url" : "https://redis.io/",
"tags" : [
"redis",
"database",
"NoSQL"
],
"likes" : 150.0
}操作 | 格式 | SQL中的类似语句 |
|---|---|---|
等于 | {<key>:<value>} | where title = 'MongoDB 教程' |
小于 | {<key>:{$lt:<value>}} | where likes < 50 |
小于或等于 | {<key>:{$lte:<value>}} | where likes <= 50 |
大于 | {<key>:{$gt:<value>}} | where likes > 50 |
大于或等于 | {<key>:{$gte:<value>}} | where likes >= 50 |
不等于 | {<key>:{$ne:<value>}} | where likes != 50 |
MongoDB 教程的所有文档;db.article.find({'title':'MongoDB 教程'})db.article.find({'likes':{$gt:50}})find()方法传入多个键,以逗号隔开来实现,例如查询title为MongoDB 教程并且by为Andy的所有文档;db.article.find({'title':'MongoDB 教程','by':'Andy'})$or操作符实现,例如查询title为Redis 教程或MongoDB 教程的所有文档;db.article.find({$or:[{"title":"Redis 教程"},{"title": "MongoDB 教程"}]})Redis 教程或者"MongoDB 教程的所有文档。db.article.find({"likes": {$gt:50}, $or: [{"title": "Redis 教程"},{"title": "MongoDB 教程"}]})limit()方法,语法如下;db.collection.find().limit(NUMBER)db.article.find().limit(2)skip()方法,语法如下;db.collection.find().limit(NUMBER).skip(NUMBER)db.article.find().limit(2).skip(1)sort()方法对数据进行排序,sort()方法通过参数来指定排序的字段,并使用1和-1来指定排序方式,1为升序,-1为降序;db.collection.find().sort({KEY:1})db.article.find().sort({likes:-1})createIndex()方法来创建索引,语法如下;db.collection.createIndex(keys, options)
# background:建索引过程会阻塞其它数据库操作,设置为true表示后台创建,默认为false
# unique:设置为true表示创建唯一索引
# name:指定索引名称,如果没有指定会自动生成db.article.createIndex({"title":1,"description":-1}, {background: true})db.article.getIndexes()
/* 1 */
[
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "test.article"
},
{
"v" : 2,
"key" : {
"title" : 1.0,
"description" : -1.0
},
"name" : "title_1_description_-1",
"ns" : "test.article",
"background" : true
}
]aggregate()方法,类似于SQL中的group by语句,语法如下;db.collection.aggregate(AGGREGATE_OPERATION)操作符 | 描述 |
|---|---|
$sum | 计算总和 |
$avg | 计算平均值 |
$min | 计算最小值 |
$max | 计算最大值 |
db.article.aggregate([{$group : {_id : "$by", sum_count : {$sum : 1}}}])
/* 1 */
{
"_id" : "Andy",
"sum_count" : 2.0
}
/* 2 */
{
"_id" : "Ruby",
"sum_count" : 1.0
}db.article.aggregate([{$group : {_id : "$by", avg_likes : {$avg : "$likes"}}}])
/* 1 */
{
"_id" : "Andy",
"avg_likes" : 100.0
}
/* 2 */
{
"_id" : "Ruby",
"avg_likes" : 100.0
}$regex操作符来设置匹配字符串的正则表达式,可以用来模糊查询,类似于SQL中的like操作;教程的文档;db.article.find({title:{$regex:"教程"}})$options操作符;db.article.find({title:{$regex:"elasticsearch",$options:"$i"}})参考:https://juejin.cn/post/6844904150635921422