美文网首页
MongoDB数据库插入、更新和删除操作

MongoDB数据库插入、更新和删除操作

作者: 深思海数_willschang | 来源:发表于2016-09-26 13:53 被阅读1129次

Insert操作

Insert操作是MongoDB插入数据的基本方法,对目标集合使用Insert操作,会将该文档添加到MongoDB并自动生成相应的ID键。文档结构采用类似JSON的BSON格式。插入时只是简单地将文档存入数据库中,不进行额外的验证,也不会执行代码,所以不存在注入式攻击的可能。

插入操作主要有单条插入和批量插入两种形式

1.1 单条插入操作


insert_single.png
db.col.insert({field1:"",field2:"",field3:"",...});

1.2 批量插入操作

MongoDB对批量插入的支持是通过传递多个文档组成的数组到数据库来实现的。

Paste_Image.png
var 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 } ] }

相关文章

  • MongoDB数据库插入、更新和删除操作

    Insert操作 Insert操作是MongoDB插入数据的基本方法,对目标集合使用Insert操作,会将该文档添...

  • 记一次mysql死锁问题

    场景:innodb下不同的事务进行更新和插入操作导致数据库死锁,代码如下,在批量插入之前,进行了逻辑删除操作,这段...

  • Mongodb基本操作

    mongodb数据库管理: Mongodb插入文档: Mongodb更新文档 Mongodb删除文档: Mongo...

  • T-SQL 之 MERGE INTO(2)

    官网地址:使用 MERGE 插入、更新和删除数据 使用 MERGE 语句执行以下操作: 有条件地在目标表中插入或更...

  • Statement执行DQL语句

    一.数据库插入操作 二.数据库跟新操作 三.删除操作

  • mongodb及express框架(0812)

    安装mongodb mongodb增删改查操作 插入数据 查询数据 插入多条数据 切换数据库并进入 test 修改...

  • MongoDB常用命令

    创建/删除数据库 创建/删除集合 插入文档 MongoDB 使用 insert() 或 save() 方法向集合中...

  • Go 中使用Monogo详解

    使用GoLang操作MongoDB 获取包 连接数据库 将连接到 mongoDB的函数抽出 插入一条数据 批量插入...

  • 8.13兄弟会

    MongoDB curd操作 建立数据库 >use mini 插入 插入一条记录: >db.users.inser...

  • nodejs使用mongodb将string类型id转换为Obj

    一、问题描述 通过NodeJs操作MongoDb数据库,在删除操作中使用主键id做为条件: 有接触过mongodb...

网友评论

      本文标题:MongoDB数据库插入、更新和删除操作

      本文链接:https://www.haomeiwen.com/subject/csrqyttx.html