MongoDB基本操作

一、MongoDB数据库操作

1、查看数据库:show dbs

2、创建数据库:use myDB

3、统计数据库信息:db.stats()

4、删除数据库:db.dropDatabase()

二、集合操作

1、创建集合:db.createCollection("myCollection")

2、查询集合:show tables/show collections

3、查看集合详细信息:db.getCollectionInfos()

4、重命名集合:db.myCollection.renameCollection("myCol")

5、删除集合:db.myColl.drop()

6、定长集合:db.myCollection("myCollection",{capped:true,size:10000})

capped:是否定长,true为定长

size:集合中文档数量

三、MongoDB文档操作

基本符号信息:

$gt:大于
$lt:小于
$gte:大于或等于
$lte:小于或等于

$ne:不等于

1、插入文档

(1)db.stuinfo.insert([{_id:003,name:'harry',age:18},{_id:004,name:'curry',age:19}])

(2)db.stuinfo.save({_id:002,name:'nancy',age:19})

2、更新文档

(1)update() 方法用于更新已存在的文档。

格式:db.collection.update(<criteria>,<objNew>,upsert,multi,writeConcern)

upsert : 可选,这个参数的意思是,如果不存在 update 的记录,是否插入 objNew,true

为插入,默认是 false,不插入。

multi : 可选,mongodb 默认是 false,只更新找到的第一条记录,如果这个参数为 true,

就把按条件查出来多条记录全部更新。

例:

(2)save() 方法通过传入的文档来替换已有文档。

db.collection.save(<document>,{writeConcern:<document>})

例:db.stuinfo.save({_id:2,name:'curry',age:20})

(3)文档替换

 (4)文档修改器

  • $inc(增加和减少,只针对数字型)
  • $set(可以完成特定需求的修改):更新集合中的文档, $set 用来指定一个键的值,如果这个键不存在,则创建它。

例:

1、给name为user1的文档添加address,可以使用命令:db.c1.update({name:”user1”},{$set:{address:”bj”}},0,1)

2、将name为user1的文档修改address为tj,其它键值对不变,命令为: db.c1.update({name:”user1”},{$set:{address:”tj”}},0,1) 更新集合中的文档, $unset 用来删除某个键,

3、删除name为user1的文档中的address键,可以使用命令: db.c1.update({name:”user1”},{$unset:{address:1}},0,1)

  • $push修改器(完成数组的插入)

  • $addToSet(向文档中数组插入数值)

(5)更新多个文档

db.表名.update({x:1},{$set:{x:99}},false,true)

3、删除文档

(1)删除集合下全部文档

db.col.deleteMany({})

或 db.col.remove({})

具体如下图所示

(2)删除指定条件的文档

删除集合 stuinfo 中 name 等于王五的全部文档:

db.stuinfo.deleteMany({name:'王五'})

删除 age 等于 18 的一个文档:

db.stuinfo.deleteOne({age:18})

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值