一、MongoDB概念解析(对比MySQL学习):

举个例子:

MongoDB可视化操作工具:推荐Robomongo

二、MongoDB默认的概念:

1、MongoDB的单个实例可以容纳多个独立的数据库,并且每个数据库都有自己的集合和权限,存放在不同的文件中

2、MongoDB默认的数据库为“db”,这个数据库存储在data目录中

三、MongoDB基本命令:

1、数据库命令

show dbs:查询数据库的列表(MongoDB默认当该数据库中没有插入任何数据时,不会显示该数据库)

db:查看当前数据库对象或集合

use DATABASE_NAME:可以切换到指定的数据库(当该数据库不存在时就创建该数据库)

db.dropDatabase():删除当前数据库

2、插入(insert()和save()两种方式插入文档)

2.1 insert

db.COLLECTION_NAME.insert(document)

举个例子:在当前数据库的col集合中插入一个文档

PS:上面例子中col是当前数据库中的一个集合,如果该集合不存在,MongoDB会先创建该集合,然后向集合中插入数据

也可以换个方式插入:先定义一个变量document,然后插入,如下:

2.2 save

上述的操作也可以使用save来完成,save和insert的区别如下:

当插入的数据在MongoDB中存在相同的主键_id时,

使用save会将数据库中原来的数据进行更新

使用insert会报错,错误为:E11000 duplicate key error collection: test.col index: _id_ dup key: { : 2.0 }

2.3 插入单条数据和插入多条数据

3、更新(update和save两种方式)

3.1 update:更新已存在的文档

语法格式:

参数说明:

query:查询条件,类似mysql中的update语句where后面的部分

update:更新操作,类似mysql中的update语句set后面的部分

upsert(可选):表示如果没有query匹配到的记录,是否作为一条新的记录插入,默认为false,不插入

multi(可选):表示是否只更新query匹配到的第一条记录,默认是false,只更新匹配到的第一条

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

异常级别配置:

举个例子:

把上面这条记录的crud的改为更新数据的语句如下:

更多demo:

3.2 save方法:通过传入的文档,替换已有的文档

语法如下:

参数说明:

document:文档数据

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

PS:使用save方法时,mongodb会根据_id来判断是否已存在该条数据,即不能通过name="xxx"来匹配已有的一条记录,且save会将新传入的文档完全替换掉匹配到的已有文档

举个例子:

已有记录

save语句

执行结果

3.3 updateOne和updateMany

MongoDB从3.2版本开始,支持向指定集合更新单个文档和多个文档

更新单个文档:

更新多个文档:

4、删除

4.1 remove

语法格式如下:

MongoDB2.6版本以后remove的语法格式如下(以前的语法格式依然兼容):

参数说明:

query(可选):查询条件,类型mysql中delete语句后面的where部分

justOne(可选):表示是否只删除匹配到的第一个文档,0或false表示删除所有匹配到的数据,其他表示只删除匹配到的第一个

writeConcern(可选):表示抛出异常的级别(参考update的异常级别)

举个例子:

删除msg为mongodb的一条记录

删除所有的数据(类似mysql中的truncate)

4.2 deleteOne和deleteMany(推荐)

删除指定集合中的全部文档

删除指定集合中msg为mongodb的所有文档

删除指定集合中msg为mongodb的一个文档

5、查询

5.1 基本查询

语法格式如下:

参数说明:

query(可选):使用查询操作符指定查询条件,类似Mysql中select的where部分

projection(可选):使用投影操作符指定返回的键,省略该参数,即可返回文档中所有的键值(默认省略)

举个例子:

查询集合col中的所有文档

查询集合col中msg为mongodb的所有文档

查询集合col中的msg为mongodb的一个文档

PS:据说是用pretty方法可以以格式化的方式来显示所有文档(使用robomongodb时,可以选择显示结果的方式,与我们的查询语句中是否加上pretty方法无关)

projection的用法

建议:在使用remove方法删除集合中的某条记录时,先使用find方法来执行一下判断的条件,验证是否正确

5.2 MongoDB与RDBMS的where语句比较

大于、等于、小于

AND条件

MongoDB的find方法可以传入多个键值,不同键值以逗号“,”分开,等同于mysql中的AND条件

语法格式为:

等同于

WHERE key1=val1 AND key2=val2

举个例子:

OR条件

MongoDB使用$or来表示OR条件语句

举个例子:

AND和OR联合使用:

等同于Mysql语句为:'where likes>50 AND (by = '菜鸟教程' OR title = 'MongoDB 教程')'

参考资料:

http://www.runoob.com/mongodb/mongodb-tutorial.html

一 MongoDB入门的更多相关文章

  1. MongoDB 入门之基础 DCL

    此文章主要记录部分主要的 MongoDB 的 DCL 操作. MongoDB 默认不需要用户名和密码就可以用 mongodb.exe 登录 一.开启 MonogoDB 的权限模式 修改 MongoDB ...

  2. MongoDB入门三:MongoDB shell

    MongoDB shell MongDB shell是一个功能完备的Javascript解释器,可以运行Javascript程序.也可以用于连接MongoDB服务器,执行脚本,对数据库进行操作.类似于 ...

  3. MongoDB 入门之查询(find)

    MongoDB 入门之查询(find) 1. find 简介 (1)find的第一个参数决定了要返回哪些文档. 空的查询文档会匹配集合的全部内容.默认就是{}.结果将批量返回集合c中的所有文档. db ...

  4. MongoDB入门简介

    MongoDB入门简介 http://blog.csdn.net/lolinzhang/article/details/4353699 有关于MongoDB的资料现在较少,且大多为英文网站,以上内容大 ...

  5. mongodb入门教程二

    title: mongodb入门教程二 date: 2016-04-07 10:33:02 tags: --- 上一篇文章说了mongodb最基本的东西,这边博文就在深入一点,说一下mongo的一些高 ...

  6. mongodb入门教程

    title: mongodb入门教程 date: 2016-04-06 14:47:18 tags: --- 为什么要认识呢,因为这玩意就一傻逼 借用一下百科的介绍 MongoDB 是一个介于关系数据 ...

  7. MongoDb 入门教程

    MongoDb 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 它是可扩展的高性能数据存储解决方案,经常被用于非关系型数据的存储,能存储海量的数据. 常 ...

  8. MongoDB入门必读(概念与实战并重)

    MongoDB入门必读(概念与实战并重) 一.概述 MongoDB是一个基于分布式文件存储的数据库开源项目.由C++语言编写.旨在为WEB应用提供可护展的高性能数据存储解决方案. MongoDB是一个 ...

  9. mongodb入门很简单(3)

     ##简单的mongodb入门命令## 1.show dbs;      //查看当前数据库 2.use databaseName;         //选库 3.show tables/collec ...

  10. MongoDB入门实践

    MongoDB入门实践 简单介绍MongoDB,包括MongoDB的使用场景.和MySQL的对比.安装部署.Java客户端访问及总结 MongoDB? 我们遵循需求驱动技术的原则,通过一个场景来引入M ...

随机推荐

  1. Java集合Stream类filter的使用

    之前的Java集合中removeIf的使用一文写了使用removeIf来实现按条件对集合进行过滤.这篇文章使用同样是JDK1.8新加入的Stream中filter方法来实现同样的效果.并且在实际项目中 ...

  2. aptitude软件状态标志i、v、p

    输出的结果分三栏,分别为状态.包名和描述.而状态则由p.i.v等字母表示.查询后才知道这些标识的含义是这样的: i - 包已经成功安装,并且所有依赖都满足. c - 包已经被移除,但是配置文件被保留. ...

  3. 微信小程序云开发-列表下拉刷新

    一.json文件开启页面刷新 开启页面刷新.在页面的json文件里配置两处: "enablePullDownRefresh": true, //true代表开启页面下拉刷新 &qu ...

  4. java反序列化提取payload之xray 高级版的shiro回显poc的提取过程

    本文中xray高级版shiro payload来源于雷石安全实验室公众号发布的shiroExploit.jar 感谢雷石安全实验室,雷石安全实验室牛逼 本文主要描述如何从shiro的payload中提 ...

  5. vue tab实现右定位

    呈现效果 利用v-if进行判断,登页面完全加载完毕后,显示tab页, 利用name标签,实现选择哪个tab <template> <el-tabs v-if="displa ...

  6. mybatis介绍以及配置

    一.概念 1.作用:简化dao层,是框架的一部分,常叫SSM,或SSI 2.历史:之前的版本叫ibatis,三版之后叫mybatis 3.什么是orm?object,relational,mappin ...

  7. 第七篇 -- photoshop cs6 激活

    下载photoshop cs6破解版 下载amtlib.dll 破解就是将amtlib.dll替换,路径:C:\Program Files\Adobe\Adobe Photoshop CS6 (64 ...

  8. 第十一篇 -- 如何实现MFC窗口的最大化以及控件随最大化

    这一篇介绍的是怎么实现MFC窗口的最大最小化,以及里面控件大小也随之改变 第一步:实现窗口最大最小化 首先右击窗口空白处,打开properties,将里面的MaximizeBox和MinimizeBo ...

  9. linux 之awk--格式化文本信息

    https://www.cnblogs.com/xudong-bupt/p/3721210.html awk是行处理器: 相比较屏幕处理的优点,在处理庞大文件时不会出现内存溢出或是处理缓慢的问题,通常 ...

  10. SpringData JPA 使用原生 SQL

    在实现个人博客系统的归档功能的时候,遇上这样的需求: 先把数据库中所有条目的时间按照年月分组,并查询出年月(String)的列表 根据年月字符串查询符合条件的博客,并返回博客列表 由于数据访问层使用的 ...