上一篇介绍了MongoDB在Windows平台下的安装,这一篇介绍一下MongoDB的一些基本操作命令。

下面我们直奔主题,用简单的实例依次介绍一下。

> 查看所有数据库 (show dbs)

> 插入文档 (insert)

格式:> db.COLLECTION_NAME.insert(document)

所有存储在集合中的数据都是BSON格式。

BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON。

下面在student集合中插入两条数据。

由于操作窗口是一个javascript shell,所以这里也可以使用js的写法。

由于文档是采用"K-V"格式存储的,JSON里面的Value可以是字符串,可以是数组,也可以是内嵌的一个JSON对象,所以BSON也同样。

> 查询文档 (find)

格式:>  db.COLLECTION_NAME.find()

find() 方法显示所有文档。

注意“_id": 这个字段是数据库默认给我们加的GUID,目的是保证数据的唯一性。

另外find() 后面加上pretty() 方法以格式化的方式来显示所有文档。看起来会更舒服一点。

当然find()操作不只是查所有文档,还可以像sql那样带各种条件去查询。

MongoDB中条件操作符有以下:

 1)$gt (大于)、$lt(小于)、$gte(大于等于)、$lte(小于等于)

实例如下:

写法很简单,对照着实例很容易理解,这里就不做讲解了。

2)$or(或者)、$in(包含在)、$nin(不包含在)

实例如下:

写法很简单,对照着实例很容易理解,这里就不做讲解了。

> 高级查询

  1)查询数组

对于数组,我们可以这样理解:数组中每一个元素都是这个键值对键的一个有效值

例如:查询student集合里兴趣爱好为篮球的文档。

我们可以看到只要爱好包含篮球的文档就可以查询出来。

那么如果多个呢。例如:查询student集合里兴趣爱好为篮球和吉他的文档。

我们可以看到虽然篮球和吉他在集合里存在,但是却查询不出来。

如果我们要匹配多个数组,就需要条件操作符$all.

例如:还是查询查询student集合里兴趣爱好为篮球和吉他的文档。

我们可以看到数组里只要包含条件值,都能被查询出来,而且顺序可以不同。

  2)根据数组位置精确查找

我们知道数组索引是从0开始,所以根据索引位置精确查找到数组某一位。

例如:查询第一位为篮球的,第二位为吉他的。

  3)数组截取 $slice

这里需要知道find函数里还有第二个参数,也就是用来控制需要显示哪些键值。1为显示,0为不显示。

例如:显示name和age键值

例如:显示name和age,不显示_id.

  继续说到$slice,数组截取,下面看下实例。

 

可以看到值为1的时候,表示取数组里的前一位值,同理为2时,取数组前两位值。

为-1的时候,表示取数组最后一位,同理为-2时,取数组后两位值。

为[1,3]时,表示跳过第一位,取接下来的三位,如果不够三位,那么有几位就取几位。

  4)内嵌文档查询

我们可以看到使用点表示法,深入到内嵌文档内部的键,来查询内嵌文档。

> 更新文档 (update)

格式:db.collection.update(<query>,<update>,{upsert:<boolean>,multi:<boolean>,writeConcern:<document>})

参数说明:

query :  update的查询条件,类似sql update查询内where后面的条件。

update : update的对象和一些更新的操作符(如$set,$inc)等,也可以理解为sql update查询内set后面的值。

upsert :  可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。

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

writeConcern :可选,抛出异常的级别。

  1)基本修改

 

  2)$set (直接设置值)

将jack的年龄修改为21岁。

 

  3)$inc (在数字型的键值的原有值的基础上增加)

将jack的年龄增加5岁。

 

  4)upsert ( 如果不存在记录,true为插入新的文档,false为不插入,默认值为false)

  5) multi (默认为false,只更行符合条件的第一条记录,如果为true,则更新符合条件的全部记录

为false的情况:

为true的情况:

> 删除 (remove)

格式:db.collection.remove(<query>,{justOne:<boolean>,writeConcern:<document>})

参数说明:

justOne : (可选)如果设为 true 或 1,则只删除一个文档。

query :(可选)删除的文档的条件

writeConcern :(可选)抛出异常的级别。

基本用法很简单,看下实例。

注意:remove中如果不带参数将删除所有数据,不可撤回,所以要谨慎。

基本的增删改查命令的使用就介绍到这里,下一篇学习一些常用的聚合函数。

MongoDB学习总结(二) —— 基本操作命令(增删改查)的更多相关文章

  1. MVC3+EF4.1学习系列(二)-------基础的增删改查和持久对象的生命周期变化

    上篇文章中 我们已经创建了EF4.1基于code first的例子  有了数据库 并初始化了一些数据  今天这里写基础的增删改查和持久对象的生命周期变化 学习下原文先把运行好的原图贴来上~~ 一.创建 ...

  2. MongoDB学习day07--mongoose入门,数据库增删改查,默认参数,模块化

    一.mongoose介绍 Mongoose 是在 node.js 异步环境下对 mongodb 进行便捷操作的对象模型工具. Mongoose 是 NodeJS 的驱动, 不能作为其他语言的驱动. M ...

  3. Mysql学习笔记(六)增删改查

    PS:数据库最基本的操作就是增删改查了... 学习内容: 数据库的增删改查 1.增...其实就是向数据库中插入数据.. 插入语句 insert into table_name values(" ...

  4. SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询

    SQL Server知识点回忆篇(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询 1. insert 如果sql server设置的排序规则不是简体中文,必须在简体中文字符串前加N, ...

  5. Ecmall二次开发-增删改查操作

    Ecmall二次开发-增删改查操作 Model目录includes/models 自己添加需要的model class OrdercomplainModel extends BaseModel //类 ...

  6. mongodb数据库学习【安装及简单增删改查】

    //@desn:mongodb数据库学习 //@desn:码字不宜,转载请注明出处 //@author:张慧源  <turing_zhy@163.com> //@date:2018/08/ ...

  7. Django基础学习四_数据库的增删改查

    今天主要学习两个东西 1.如何对数据库做增删改查 2.如果将数据库中的数据用html的方式返回到前台 一.对数据库中增删改查操作 1.首先需要先见表,见表的方法我们在“http://www.cnblo ...

  8. MongoDB系列(三):增删改查(CURD)

    上篇讲了MongoDB的基础知识,大家应该对MongoDB有所了解了,当然真正用的还是curd操作,本篇为大家讲解MongoDB的curd操作. 1.数据库操作 #.增 use config #如果数 ...

  9. MongoDB入门(介绍、安装、增删改查)

    文章作者公众号bigsai,已收录在回车课堂,如有帮助还请不吝啬点个赞赞支持一下! 课程导学 大家好我是bigsai,我们都学过数据库,但你可能更熟悉关系(型)数据库例如MySQL,SQL SERVE ...

随机推荐

  1. 单应性(homography)变换的推导

    矩阵的一个重要作用是将空间中的点变换到另一个空间中.这个作用在国内的<线性代数>教学中基本没有介绍.要能形像地理解这一作用,比较直观的方法就是图像变换,图像变换的方法很多,单应性变换是其中 ...

  2. stm32使用LWIP实现DHCP客户端

    LWIP是一款开源的嵌入式网络协议栈,支持的功能很多,而且能在多任务环境下和单任务裸机环境下跑,今天说说他的移植过程,芯片为STM32,网卡为ENC28J60,无操作系统 首先下载LWIP的源代码,我 ...

  3. 关于iOS后台模式

    https://onevcat.com/2013/08/ios7-background-multitask/ http://zhidao.baidu.com/link?url=NUOMrLGB6Odr ...

  4. Codeforces Round 212 Div 2 报告(以前没写完,现在也没心情补了,先就这样吧)

    A. Two Semiknights Meet 题目大意:有一个8x8的棋盘,上面放有两个骑士,骑士以“田字”的方式走.每个方格都被定义为good或者bad,问骑士能否在good的格子中相遇? 由于骑 ...

  5. Recovering a WiredTiger collection from a corrupt MongoDB installation

    Reference: http://www.alexbevi.com/blog/2016/02/10/recovering-a-wiredtiger-collection-from-a-corrupt ...

  6. android——网络操作(一)连接网络

    连接网络 一,包含许可 <uses-permissionandroid:name="android.permission.INTERNET"/> <uses-pe ...

  7. 隐马尔可夫模型(HMM)原理

    本文主要讨论隐马尔科夫模型的三大要素,三大假设和三大问题. 1.引入 隐马尔可夫模型是一个关于时序的概率模型,它描述了一个由隐藏的马尔可夫链生成状态序列,再由状态序列生成观测序列的过程.其中,状态之间 ...

  8. http://begin.lydsy.com/JudgeOnline/problem.php?id=2770(PKU2503 Babelfish)

    2770: PKU2503 Babelfish Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 2  Solved: 2[Submit][Status][ ...

  9. Git Flow——Git团队协作最佳实践

    规范的Git使用 Git是一个很好的版本管理工具,不过相比于传统的版本管理工具,学习成本比较高. 实际开发中,如果团队成员比较多,开发迭代频繁,对Git的应用比较混乱,会产生很多不必要的冲突或者代码丢 ...

  10. 环信 之 iOS 客户端集成三:基础功能

    SDK中,大部分与网络有关的操作,都有三种方法: 同步方法 通过delegate回调的异步方法.要想能收到回调,必须要注册为:[[EaseMob sharedInstance].chatManager ...