Insert操作
Insert操作是MongoDB插入数据的基本方法,对目标集合使用Insert操作,会将该文档添加到MongoDB并自动生成相应的ID键。文档结构采用类似JSON的BSON格式。插入时只是简单地将文档存入数据库中,不进行额外的验证,也不会执行代码,所以不存在注入式攻击的可能。
插入操作主要有单条插入和批量插入两种形式
1.1 单条插入操作
insert_single.png
db.col.insert({field1:"",field2:"",field3:"",...});
1.2 批量插入操作
MongoDB对批量插入的支持是通过传递多个文档组成的数组到数据库来实现的。
Paste_Image.pngvar feeds = [
{_id:"10003", uid:"10001", name:"wills","msg":"这个平台不错的,可以常来帮助别人的.",state:"0"},
{_id:"10004", uid:"10001", name:"wills","msg":"你们的平台的详情页有点问题哦.",state:"0"},
{_id:"10005", uid:"10001", name:"wills","msg":"这是一个助人的平台,值得拥有的.",state:"0"},
{_id:"10006", uid:"10001", name:"wills","msg":"好的平台还是需要更多人知道的.",state:"0"}
]
db.col.insert(feeds)
这种方式的批量插入一次只能将多个文档插入到一个集合中,对于插入到多个集合可以循环调用Insert操作。
Remove操作
remove函数可以用来删除数据,它能接受一个文档作为可选参数,只有符合条件的文档才会被删除。
删除数据是永久性的,不能撤销,也不能恢复,需要谨慎。删除文档需要清空整个集合,不如直接删除集合快。
//删除name为wills的数据
db.col.remove({name:"wills"})
//全部删除整个集合
db.col.remove({});
Update操作
update函数用于修改数据库中的数据,它接收两个参数,一个是查询文档,用来查找要更新的文档,另一个是修改器文档,用来描述对找到的文档做哪些修改。
更新操作是原子性的,如果多个更新同时发生,则所有的更新都会执行,但只有最后的更新才起效果。
/*
db.collection.update( criteria, objNew, upsert, multi )
criteria : update的查询条件,类似sql update查询内where后面的
objNew : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
upsert : 这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
*/
db.col.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一条记录
db.col.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
db.col.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加进去了第一条
db.col.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加进去了
db.col.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
db.col.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一条
mongodb的更新操作符:
1) $inc
用法:{ $inc : { field : value } }意思对一个数字字段field增加value
db.col.update( { "name" : "wills" } , { $inc : { "age" : 1 } } );
2) $set
用法:{ $set : { field : value } },就是相当于sql的set field = value,全部数据类型都支持$set。
db.col.update({name:"wills"},{$set: {age: 30}});
3) $unset
用法:{ $unset : { field : 1} }顾名思义,就是删除字段
db.col.update({name:"wills"}, {$unset: {age:1}});
4) $push
用法:{ $push : { field : value } },把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去
db.col.update( { "name" : "wills" } , { $push : { "books": "nosql" } } );
5) $pushAll
用法:{ $pushAll : { field : value_array } },同$push,只是一次可以追加多个值到一个数组字段内。
db.col.update( { "name" : "wills" } , { $pushAll : { "books": [ "nosql","mysql"] } } );
6) $addToSet
用法:{ $addToSet : { field : value } },增加一个值到数组内,而且只有当这个值不在数组内才增加。
db.col.update( { "name" : "wills" } , { $addToSet : { "books": {$each : ["python","nodejs"] } } } );
7) $pop
删除数组内的一个值用法:
删除最后一个值:{ $pop : { field : 1 } }
删除第一个值:{ $pop : { field : -1 } }
注意,只能删除一个值,也就是说只能用1或-1
db.col.update( { "name" : "wills"} , { $pop : { "books": -1 } } );
8) $pull
用法:$pull : { field : value } }从数组field内删除一个等于value值。
db.col.update( { "name" : "wills"} , { $pull : { "books": "nodejs" } } );
9) $pullAll
用法:{ $pullAll : { field : value_array } }同$pull,可以一次删除数组内的多个值
db.col.update( { "name" : "wills" } , { $pullAll : { "books": [ "nosql" , "mysql" ] } } );
10) $ 操作符
$是他自己的意思,代表按条件找出的数组里面某项他自己
> t.find()
//{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 3 }, { "by" : "jane", "votes" : 7 } ] }
> t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false, true)
> t.find()
//{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 4 }, { "by" : "jane", "votes" : 7 } ] }
网友评论