MongoDB常用命令汇总之插入、更新和删除操作详解。
来源:互联网 发布:d3.js pdf 编辑:程序博客网 时间:2024/05/22 13:05
Insurt操作
insurt操作是MongoDB插入数据的基本方法,对目标集合使用Insert操作,会将该文档添加到MongoDB并自动生成相应的ID键。文档结果采用类似JSON的BSON格式。常见的插入操作主要有单挑插入和批量插入两种形式。插入时只是简单地将文档存入数据库汇总,不进行额外的验证,也不会执行代码,所以不存在注入式攻击的可能。
单条插入
批量插入
mongoDB对批量插入的支持是通过传递多个文档组成的数组到数据库来实现的。由于它插入数据是通过发送TCP请求的,这样只需发送单个TCP请求,且数据库无需处理大量的消息头,减少插入时间。这种方式的批量插入一次只能讲多个文档插入到一个集合中,对于插入到多个集合可以循环调用Insert操作。
remove操作
remove函数可以用来删除数据,它能接受一个文档作为可选参数,只有符合条件的文档才会被删除。删除数据是永久的,不能撤销,也不能恢复,需要谨慎。删除文档需要清空整个结婚,不如直接删除集合快。
update操作
updagte函数用于修改数据库中的数据,它接受两个参数,一个是查询文档,用来查找要更新的文档,另一个是修改器文档,用于描述对找到的文档做哪些修改。更新操作是原子性的,如果多个更新同时发生,则所有的更新都会执行,但最后的更新是最终赢家。
整体更新(文档替换)
局部更新(修改器)
部分更新是通过原子的更新修改器实现的,使用修改器时除了“_id”的值不能改变,其他任何值都能改变。文档替换是可以改变所有制的。
$inc修改器:将指定属性的值增加特定的步长,如果键不存在则创建它。
set修改器:用来指定一个键的值,如果不存在则创建它。
$push:数组修改器,如果指定的键存在,则向已有的数组末尾加入一个元素,键不存在则会创建一个新的数组。
upsert操作
upsert操作具有saveOrUpdate的功能,如果没有文档符合更新条件,则以更新条件和更新文档为基础创建一个新的文档。如果有符合更新条件的文档,则正常更新。创建新文档时会以条件文档作为基础,将修改器作用其之上。Upsert操作是原子性的,高效的。
批量更新
批量更新只需将update的第4个参数设置为true即可。
瞬间完成
上面的插入、删除和更新操作都是瞬间完成的,它们不需要等待数据库响应。这样的实现可以获取高性能,速度非常快,只会受客户端发送发送速度的和网络速度的制约。但由于不会获取服务器状态,所以不能保证操作顺利完成。这对于付费系统,安全性较高的系统是不可行的,此时对这些操作需要使用它们的安全版本。安全版本会在操作执行后立即运行getLastError命令,来检查是否执行成功。如果失败一般会抛出可捕获的异常,然后我们可以在代码中处理。
请求和连接
数据库会为每个MongoDB数据库连接创建一个队列,存放这个连接的请求,客户端新发送的请求会被放到队列的末尾。只有队列中的请求都执行完毕,后续的请求才会执行。即对于单个连接来说,请求都是顺序执行不存在并发问题,所以它总能读到自己写的东西。但对于不通的连接就有可能出现读取和写入不一致的问题,在驱动程序使用连接池要特别注意此行为。
- MongoDB常用命令汇总之插入、更新和删除操作详解。
- MongoDB数据库插入、更新和删除操作详解
- MongoDB数据库插入、更新和删除操作详解
- MongoDB数据库插入、更新和删除操作详解
- MongoDB数据库插入、更新和删除操作详解
- MongoDB数据库插入、更新和删除操作详解
- mongodb[三] 文档操作:插入、更新、删除
- MongoDB常用命令汇总之语句块操作。
- MongoDB常用命令汇总之条件操作符。
- MongoDB 插入、更新、删除
- mongodb中的更新和插入操作
- MongoDB常用命令插入更新类
- MongoDB常用命令汇总之修改、添加、删除集合数据。
- MongoDB数据插入、删除、更新
- MongoDB的学习(1)--文档的插入、删除和更新
- MySQL学习之插入、更新和删除
- MongoDB常用命令汇总之索引。
- 插入、删除和更新
- 如何限制一个类对象只在栈(堆)上分配空间
- java判断完数
- 常见面试题
- webstorm 设置ES6语法支持以及添加vuejs开发配置
- Ubuntu修改环境变量
- MongoDB常用命令汇总之插入、更新和删除操作详解。
- HTML5开发和布局(待补充)
- MySQL使用case when报错问题记录
- linux 下PCIE控制器设备树 学习
- log中的Total PSS by OOM adjustment
- java之约会
- Linux基础
- java学习之路(4)-常量 、变量与数据类型
- CSS基础属性2