您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

MongoDB中常用的语句总结

2025/2/28 14:29:47发布14次查看
本篇文章给大家带来的内容是关于mongodb中常用的语句总结,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
如果觉得 mongodb 语句不太好理解,可以和 sql 语句进行对比,学起来要容易很多。
1. 查询(find)
查询所有结果
select * from articledb.article.find()
指定返回哪些键
select title, author from articledb.article.find({}, {title: 1, author: 1})
where条件
select * from article where title = mongodbdb.article.find({title: mongodb})
and条件
select * from article where title = mongodb and author = goddb.article.find({title: mongodb, author: god})
or条件
select * from article where title = mongodb or author = goddb.article.find({$or: [{title: mongodb}, {author: god}]})
比较条件
select * from article where read >= 100;db.article.find({read: {$gt: 100}})
> $gt(>)、$gte(>=)、$lt(d465e952edbc4325ec7a8892c05fa947= 100 and read c6e658a5d7462ad87366ba593fef8f89 100db.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 = 123db.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 articledb.article.remove()
删除指定文档:
delete from article where title = "mongodb" db.article.remove({title: "mongodb"})
以上就是mongodb中常用的语句总结的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product