Mongo的文档操作之增删改查

文档操作
1、插入文档

a.使用insert()方法插入
语法:db.集合名.insert(文档)
语法:db.集合名.insert([文档1,文档2,文档3,…])
例如 插入一个学生

db.student.insert({id:102,name:"xiaoli",age:20,gender:1,isDelete:0})

插入多个学生

db.student.insert({id:103,name:"xiaoliu",age:22,gender:1,isDelete:0},{id:104,name:"xiaolu",age:21,gender:0,isDelete:0})

b.使用save()方法插入文档
语法:db.集合名.save(文档)

​ 说明:如果不指定_id字段,save()方法类似于insert()方法。如果指定_id字段,则会更新_id字段的数据

db.student.save({id:105,name:"poi", age:22, gender:1, isDelete:0})
db.student.save({_id:ObjectId("59950962019723fe2a0d8d17"),name:"poi", age:23, gender:1,isDelete:0})
2、文档更新

a、update()方法用于更新已存在的文档
语法:

db.集合名.update(
            query,
            update,
            {
                upsert:<boolean>,
                multi:<boolean>,
            }
        )

参数说明:

 query:update的查询条件,类似于sql里update语句内where后面的内容

 update:update的对象和一些更新的操作符($set,$inc)等,$set直接更新,$inc在原有的基础上累加后更新

 upsert:可选,如果不存在update的记录,是否当新数据插入,true为插入,False为不插入,默认为false。

multi:可选,mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就按照条件查找出来的数据全部更新

例如:将学生表中的xiaoliu的年龄改成25

db.student.update({name:"xiaoliu"},{$set:{age:25}})

累加 如果原来是15岁,现在变成40岁

db.student.update({name:"xiaoliu"},{$inc:{age:25}})

 全改:

db.student.update({name:"poi"},{$set:{age:42}},{multi:true}) 

#不插入,但是更新多条
db.aaa.update({name:'hule',age:44},{$set:{name:'hule22'}},false,true)

#如果不能匹配则插入,如果匹配则更新多条
db.aaa.update({name:'hule',age:44},{$set:{name:'hule55'}},true,true)
3、文档删除

说明:在执行remove()函数前,先执行find()命令来判断执行的条件是否存在是一个良好习惯

语法:

 db.集合名.remove(
            query,
            {
                justOne:<boolean>,
            }
        )

参数说明:
​ query:可选,删除的文档的条件
​ justOne:可选,如果为true或1,则只删除一个文档

db.student.remove({name:"xiaoliu"})

#####4、文档查询
a、find()方法

语法:db.集合名.find()

查询集合下所有的文档(数据):

db.student.find()

b、find()方法查询指定列

语法:db.集合名.find(
            query,
            {
                <key>:1,
                <key>:1
            }
        )

参数说明:
​ query:查询条件
​ key:要显示的字段,1表示显示

 db.student.find({gender:0},{name:1,age:1})
 db.student.find({},{name:1,age:1})

c、pretty()方法以格式化的方式来显示文档

db.student.find().pretty()

d、findOne()方法查询匹配结果的第一条数据

db.student.findOne({gender:0})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值