一、介绍:

数据库分为关系型数据库和非关系型数据库

关系型数据库是建立在关系模型上的数据库,主要的有Oracle MySQL Microsoft SQL Server

NoSQL是非关系型数据存储的广义定义 有:MongoDB

MongoDB:中每个数据包包含一个或者多个集合,集合是以BSON数据结构组织起来的文档对象集合,这个数据库可以处理大量数据,也可以欲行在便宜的PC服务器集群上,里面的数据结构非常简单,存储不需要固定的表结构,易于存储对象类型的数据,因此不需要进行表与表之间的关联查询。

使用场合:网站数据 用于对像及JSON数据的存储

二、安装:

http://www.cnblogs.com/GainLoss/p/6906937.html

三、mongoDB数据类型:

mongoDB的文档使用BSON来组织数据,BSON类似于JSON, JSON只是一种简单的表示数据的方式,只包含了6中数据类型

1.null: 用于表示空值或不存在的字段

2.布尔类型: true false

3.32为整数: mongodb的控制台使用js引擎进行输入,而js仅支持64位浮点数,所以32位整数会被自动转义

4.64位整数: 和32位整数一样

5.64位浮点数: 数字的默认类型

6.字符串

7.符号:不支持这种类型,会被自动转义

8.ObecjtId类型:对象id是文档中唯一的12位的ID

9.日期:日期类型存储是从标准纪年的毫秒数,不存储时区 使用的时候加上new {'one':new Date()}

10.正则表达式 文档键值可以包含表达式{‘one’:/ho/i}

11.代码

12.数据:可以表示位数据,在数组中还可以嵌套数组

13.内嵌文档; {'x':{'name':"time","age":"12"}}

14._id和ObjectId对象:mongodb文档默认必须有一个_id 这个键的值可以是任何类型 也可以自定义 默认位ObjectId对象

四、文档查询

1.基本操作

查找:

db.person.find()查看集合person中的数据

2.返回指定的键:

指定返回name的值:db.person.find({},{"name":1})

3.条件查询:

大于$gt 小于$lt 大于等于$gte 小于等于$lte 如果有多个条件:db.person.find({"field":{"$gt":value,"$lt":value}})

4.$all匹配所有 必须满足[]内所有的值

db.person.find({"name":{"$all":["value","hourse"]}})

5.$exists判断字段是否存在

db.person.find({"field":{$exists:true}}) field代表需要判断的字段的名称

6.$count查询记录的总条数

db.person.find().count() 总的数量

7.limit返回记录数

db.person.find().limit(N) 这个就用于限制一页显示多少个数据

8.skip限制返回记录的起点

db.person.find().skip(n) 就是分页的时候从第几条开始

9.sort排序

1表示升序 -1表示降序 db.person.find().sort("age":1)

添加:

db.person.insert({"name":"123"}) 在集合person中添加一条name=123的记录

删除:

db.person.remove({'name':'123'}) 删除name是123的记录

修改:

db.person.update({"_id":"1","name":"234"}) 修改_id=1的这条记录的name改成234

db.person.save({"name":123}) 文档不存在就进行插入 存在进行更新

深入了解MongoDB的更多相关文章

  1. 【翻译】MongoDB指南/聚合——聚合管道

    [原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...

  2. 【翻译】MongoDB指南/CRUD操作(四)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...

  3. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  4. 【翻译】MongoDB指南/CRUD操作(二)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...

  5. 【翻译】MongoDB指南/CRUD操作(一)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...

  6. CRL快速开发框架系列教程十二(MongoDB支持)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  7. MongoDB系列(二):C#应用

    前言 上一篇文章<MongoDB系列(一):简介及安装>已经介绍了MongoDB以及其在window环境下的安装,这篇文章主要讲讲如何用C#来与MongoDB进行通讯.再次强调一下,我使用 ...

  8. MongoDB系列(一):简介及安装

    什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为应用提供可扩展的高 ...

  9. [原]分享一下我和MongoDB与Redis那些事

    缘起:来自于我在近期一个项目上遇到的问题,在Segmentfault上发表了提问 知识背景: 对不是很熟悉MongoDB和Redis的同学做一下介绍. 1.MongoDB数组查询:MongoDB自带L ...

  10. 用MongoDB分析合肥餐饮业

    看了<从数据角度解析福州美食>后难免心痒,动了要分析合肥餐饮业的念头,因此特地写了Node.js爬虫爬取了合肥的大众点评数据.分析数据库我并没有采用MySQL而是用的MongoDB,是因为 ...

随机推荐

  1. 8.11zju集训日记

    今天的比赛打得很不好,前一个小时的看的题目都非常难,没有做出题目,中期看到两道题,一道题是我读题,金大佬solo的,另外一道题是金大佬读题,写了代码但wa了,然后我和zz找bug,最后发现答案的范围是 ...

  2. 斑马条码打印机通过js post 打印

    <html lang="zh-ch"><head>  <meta charset="utf-8">  <meta ht ...

  3. 两个数据库通过DataTable实现差异传输

    两个主要方法 /// <summary>/// 用途:/// 用源表和目标表比较,返回差异的数据(目标表为参照物)/// /// 逻辑:/// 1.合并两个表/// 2.循环合并后得到的表 ...

  4. about rand and reflect

    select regexp_replace(reflect("java.util.UUID", "randomUUID"), "-", &q ...

  5. python : No such file or directory

    windows上写的python脚本,在linux上执行时报: No such file or directory 解决方法一# sed -i 's#\r##' mysqlchk.py 解决方法二脚本 ...

  6. Vue自定义指令实现按钮级权限控制功能

    思路: 登录:当用户填写完账号和密码后向服务端验证是否正确,验证通过之后,服务端会返回一个token,拿到token之后(我会将这个token存贮到sessionStorage中,保证刷新页面后能记住 ...

  7. getElementsByTagName 、 getElementsByName 、getElementById区别

    WEB标准下可以通过getElementById(), getElementsByName(), and getElementsByTagName()访问DOCUMENT中的任一个标签: getEle ...

  8. shell查看内存

    <1>jps<2>ps<3>free<4>df<5>top jps: 很多Java命令都在jdk的JAVA_HOME/bin/目录下面,jp ...

  9. Mybatis学习笔记13 - 动态sql之set标签

    示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; public interface EmployeeMapp ...

  10. CTeX里面CTRL-Space和中文输入法的冲突问题解决

    我使用的是windows xp,相信下面的方法也能应用到win7等windows系统上. 我希望在CTex套件的WinEdt 6.0里使用模板自动插入内容时,想快速从上到下遍历” * “并修改. 通过 ...