视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MongoDB中常用的语句总结
2020-11-09 08:41:13 责编:小采
文档


本篇文章给大家带来的内容是关于MongoDB中常用的语句总结,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

如果觉得 Mongodb 语句不太好理解,可以和 SQL 语句进行对比,学起来要容易很多。

1. 查询(find)

查询所有结果

select * from article
db.article.find()

指定返回哪些键

select title, author from article
db.article.find({}, {"title": 1, "author": 1})

where条件

select * from article where title = "mongodb"
db.article.find({"title": "mongodb"})

and条件

select * from article where title = "mongodb" and author = "god"
db.article.find({"title": "mongodb", "author": "god"})

or条件

select * from article where title = "mongodb" or author = "god"
db.article.find({"$or": [{"title": "mongodb"}, {"author": "god"}]})

比较条件

select * from article where read >= 100;
db.article.find({"read": {"$gt": 100}})
> $gt(>)、$gte(>=)、$lt(<)、$lte(<=)
 select * from article where read >= 100 and read <= 200
 db.article.find({"read": {"$gte": 100, "lte": 200}})

in条件

select * from article where author in ("a", "b", "c")
db.article.find({"author": {"$in": ["a", "b", "c"]}})

like

select * from article where title like "%mongodb%"
db.article.find({"title": /mongodb/})

count

select count(*) from article
db.article.count()

不等于

select * from article where author != "a"
db.article.find({ "author": { "$ne": "a" }})

排序

升序:

select * from article where type = "mongodb" order by read desc
db.article.find({"type": "mongodb"}).sort({"read": -1})

降序:

select * from article where type = "mongodb" order by read asc
db.article.find({"type": "mongodb"}).sort({"read": 1})
findOne():除了只返回一个查询结果外,使用方法与find()一样。

2.创建(insert)

insert into article(title, author, content) values("mongodb", "tg", "haha")
db.article.insert({"title": "mongodb", "author": "tg", "content": "haha"})

3.更新(update)

update()

语法:

db.collecion.update(query, update[, options] )

 query : 必选,查询条件,类似find中的查询条件。
 update : 必选,update的对象和一些更新的操作符(如$,$inc...)等
 options:可选,一些更新配置的对象。
 upsert:可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
 multi:可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
 writeConcern:可选,抛出异常的级别。

简单更新:

update article set title = "mongodb" where read > 100
db.article.update({"read": {"$gt": 100}}, {"$set": { "title": "mongodb"}})

save()

db.article.save({_id: 123, title: "mongodb"})

执行上面的语句,如果集合中已经存在一个_id为123的文档,则更新对应字段;否则插入。

注:如果更新对象不存在_id,系统会自动生成并作为新的文档插入。

更新操作符

MongoDB提供一些强大的更新操作符。

更新特定字段($set):

update game set count = 10000 where _id = 123
db.game.update({"_id": 123}, { "$set": {"count": 10000}})

删除特定字段($unset):

注:$unset指定字段的值只需是任意合法值即可。
递增或递减($inc)

 db.game.update({"_id": 123}, { "$inc": {"count": 10}}) // 每次count都加10

> 注意:$inc对应的字段必须是数字,而且递增或递减的值也必须是数字。

数组追加($push):

 db.game.update({"_id": 123}, { "$push": {"score": 123}})

还可以一次追加多个元素:

 db.game.update({"_id": 123}, {"$push": {"score": [12,123]}})

注:追加字段必须是数组。如果数组字段不存在,则自动新增,然后追加。

一次追加多个元素($pushAll):

 db.game.update({"_id": 123}, {"$pushAll": {"score": [12,123]}})

追加不重复元素($addToSet):

$addToSet类似集合Set,只有当这个值不在元素内时才增加:

 db.game.update({"_id": 123}, {"$addToSet": {"score": 123}})

删除元素($pop):

db.game.update({"_id": 123}, {"$pop": {"score": 1}}) // 删除最后一个元素
db.game.update({"_id": 123}, {"$pop": {"score": -1}}) // 删除第一个元素

注:$pop每次只能删除数组中的一个元素,1表示删除最后一个,-1表示删除第一个。

删除特定元素($pull):

db.game.update({"_id": 123}, {"$pull": {"score": 123}})

上面的语句表示删除数组score内值等于123的元素。

删除多个特定元素($pullAll):

db.game.update({"_id": 123}, {"$pullAll": {score: [123,12]}})

上面的语句表示删除数组内值等于123或12的元素。
更新嵌套数组的值:
使用数组下标(从0开始):

{
 address: [{place: "nanji", tel: 123}, {place: "dongbei", tel: 321}]
}
 db.game.update({"_id": 123}, {"$set": {"address.0.tel": 213}})

如果你不知道要更新数组哪项,我们可以使用$操作符( $表示自身,也就是按查询条件找出的数组里面的项自身,而且只会应用找到的第一条数组项):

 db.game.update({"address.place": "nanji"}, {"$set": {"address.$.tel": 123}})

在上面的语句中,$就是查询条件{"address.place": "nanji"}的查询结果,也就是{place: "nanji", tel: 123},所以{"address.$.tel": 123}也就是{"address.{place: "nanji", tel: 123}.tel": 123}

4. 删除(remove)

删除所有文档:

delete from article
db.article.remove()

删除指定文档:

 delete from article where title = "mongodb"
 db.article.remove({title: "mongodb"})

下载本文
显示全文
专题