MongoDB基本操作(增删改查)
基本操作
<1> insert 操作
数据库有了,下一步就是集合,这里就取集合名为“person”,要注意的就是文档是一个json的扩展(Bson)形式。
文档是采用“K-V”格式存储的,如果大家对JSON比较熟悉的话,我相信学mongodb是手到擒来,我们知道JSON里面Value可能是“字符串”,可能是“数组”,又有可能是内嵌的一个JSON对象,相同的方式也适合于BSON。
常见的插入操作也就两种形式存在:“单条插入”和“批量插入”。
① 单条插入
先前也说了,mongo命令打开的是一个javascript shell。所以js的语法在这里面都行得通,看起来是不是很牛X。
② 批量插入
这玩意跟“单条插入”的差异相信大家应该知道,由于mongodb中没有提供给shell的“批量插入方法”,没关系,各个语言的driver都打通
了跟mongodb内部的批量插入方法,因为该方法是不可或缺的,如果大家非要模拟下批量插入的话,可以自己写了for循环,里面就是insert。
我们将数据插入后,肯定是要find出来,不然插了也白插,这里要注意两点:
① “_id": 这个字段是数据库默认给我们加的GUID,目的就是保证数据的唯一性。
② 严格的按照Bson的形式书写文档,不过也没关系,错误提示还是很强大的。
日常开发中,我们玩查询,玩的最多的也就是二类:
①: >, >=, <, <=, !=, =。
②:And,OR,In,NotIn
这些操作在mongodb里面都封装好了,下面就一一介绍:
<1>"$gt", "$gte", "$lt", "$lte", "$ne", "没有特殊关键字",这些跟上面是一一对应的,举几个例子。
<3> update操作
更新操作无非也就两种,整体更新和局部更新,使用场合相信大家也清楚。
<1> 整体更新
不知道大家可还记得,我在上一篇使用update的时候,其实那种update是属于整体更新。
<2> 局部更新
有时候我们仅仅需要更新一个字段,而不是整体更新,那么我们该如何做呢?easy的问题,mongodb中已经给我们提供了两个修改器: $inc 和 $set。
① $inc修改器
$inc也就是increase的缩写,学过sql server 的同学应该很熟悉,比如我们做一个在线用户状态记录,每次修改会在原有的基础上自增$inc指定的值,如果“文档”中没有此key,则会创建key,下面的例子一看就懂。
<3> upsert操作
这个可是mongodb创造出来的“词”,大家还记得update方法的第一次参数是“查询条件”吗?,那么这个upsert操作就是说:如果我没有查到,我就在数据库里面新增一条,其实这样也有好处,就是避免了我在数据库里面判断是update还是add操作,使用起来很简单。将update的第三个参数设为true即可。
<4> 批量更新
在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单的,在update的第四个参数中设为true即可。例子就不举了。
<4> remove操作
remove中如果不带参数将删除所有数据,很危险的操作,在mongodb中是一个不可撤回的操作,三思而后行。
最新文章
- ABP理论学习之领域服务
- css绘制六边形
- discuz搬家后报错SQL:SELECT value FROM [Table]vars WHERE name=’noteexists1′的解决办法
- 大白话系列之C#委托与事件讲解(三)
- maven install与maven package 的区别
- java 高精度
- TypeScript 素描 - 装饰器
- Android正在使用Handler实现消息分发机制(两)
- Ubuntu 12.04下安装thrift 0.9
- VMware虚拟机安装
- 【一天一道LeetCode】#93. Restore IP Addresses
- sql获取当前月份的前一月,当前天的前一天,当前年的前一年
- 使用 Kubeadm 升级 Kubernetes 版本
- TCP 链接 存在大量 close_wait 等待
- Java解决小孩围圈问题
- Android8自定义广播无法收到消息
- Swift 里字符串(八)UnicodeScalarView
- ispoweroftwo 判断2的次幂
- 跟厂长学PHP7内核(一):发展史
- Unix域套接字简介
热门文章
- discuz 设置
- 访问DataGridView的Rows报了OutOfIndexRangeException错误
- 第六周作业&;实验报告四
- 启用hdfs的高可用
- pair常见用法
- [MtOI2019]永夜的报应 题解
- python变量的内存管理
- docker数据卷挂载
- Bootstrap4中栅格系统CSS中 col-sm-* col-md-* col-lg-*的意义以及当其同时具有col-xs-* col-sm-* col-md-* col-lg-*的含义
- js 继承,Object.setPrototypeOf | Object.getPrototypeOf | Object.create class