一、什么是MongoDB ?
1、MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。
2、MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
3、MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
二、历史
1、2007年10月,MongoDB由10gen团队所发展。2009年2月首度推出。
2、2012年05月23日,MongoDB2.1 开发分支发布了! 该版本采用全新架构,包含诸多增强。
3、2012年06月06日,MongoDB 2.0.6 发布,分布式文档数据库。
4、2013年04月23日,MongoDB 2.4.3 发布,此版本包括了一些性能优化,功能增强以及bug修复。
5、2013年08月20日,MongoDB 2.4.6 发布,是目前最新的稳定版。
三、主要特点
1、MongoDB的提供了一个面向文档存储,基本的思路就是将原来“行”的概念换成更加灵活的“文档”模型。一条记录可以表示非常复杂的层次关系。
2、Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
3、非常容易扩展。面对数据量的不断上涨,通常有两种方案,一种是购买更好的硬件,别一种是分散数据,进行分布式的扩展,前者有着非常大的缺点,因 为硬件通常是有物理极限的,当达到极限以后,处理能力就不可能再进行扩展了。所以建议的方式是使用集群进行扩展。MongoDB所采用的面向文档的数据模 型使其可以自动在多台服务器之间分割数据。它还可以平衡集群的数据和负载,自动重排文档。
4、MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
5、丰富的功能。包括索引、存储JavaScript、聚合、固定集合、文件存储等。
6、方便的管理,除了启动数据库服务器之外,几乎没有什么必要的管理操作。管理集群只需要知道有新增加的节点,就会自动集成和配置新节点。
安装
brew install mongodb
http://blog.sina.com.cn/s/blog_7c8dc2d50101lwka.html
一、数据库
1、一个mongodb中可以建立多个数据库。
2、MongoDB的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。
3、数据库也通过名字来标识。数据库名可以是满足以下条件的任意UTF-8字符串。
1.不能是空字符串(””)。
2.不得含有’ ‘(空格)、.、$、/、\和\0 (空宇符)。
3.应全部小写。
4.最多64字节。
4、有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库。
1.admin: 从权限的角度来看,这是”root”数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。
2.local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
3.config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
二、文档
文档是mongodb中的最核心的概念,是其核心单元,我们可以将文档类比成关系型数据库中的每一行数据。
多个键及其关联的值有序的放置在一起就是文档。MongoDB使用了BSON这种结构来存储数据和网络数据交换。
BSON数据可以理解为在JSON的基础上添加了一些json中没有的数据类型。
如果我们会JSON,那么BSON我们就已经掌握了一半了,至于新添加的数据类型后面我会介绍。
文档例子如下:
{name:”张三”,age:20,hobby:[“看书”,”旅游”,”唱歌”]}
需要注意的是:
- 文档中的键/值对是有序的。
- 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌人的文档)。
- MongoDB区分类型和大小写。
- MongoDB的文档不能有重复的键。
- 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。
文档键命名规范:
1 键不能含有\0 (空字符)。这个字符用来表示键的结尾。
2 .和$有特别的意义,只有在特定环境下才能使用。
3 以下划线”_”开头的键是保留的(不是严格要求的)。
三、集合
集合就是一组文档的组合。如果将文档类比成数据库中的行,那么集合就可以类比成数据库的表。
在mongodb中的集合是无模式的,也就是说集合中存储的文档的结构可以是不同的,比如下面的两个文档可以同时存入到一个集合中:
{“name”:”tangcaiye”}
{“Name”:”tangcaiye”,”sex”:”nan”}
注:当第一个文档插入时,集合就会被创建。
合法的集合名 - 集合名不能是空字符串””。
- 集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
- 集合名不能以”system.”开头,这是为系统集合保留的前缀。
- 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$。
四、 MongoDB 数据类型
下表为MongoDB中常用的几种数据类型。
终端中启动
首先需要指定数据库的地址:
mongod —dbpath=数据库地址
操作mongodb基础
1.创建数据库
use database_name database_name代表数据库的名字
注:如果数据库不存在,则创建数据库,否则切换到指定数据库
2.查看所有数据库
show dbs
注:我们刚创建的数据库 person 如果不在列表内, 要显示它,我们需要向 person 数据库插入一些数据 db.person.insert({name:”zhangSan”,age:30})
3.查看当前使用的数据库
db 或 db.getName()
注:db代表的是当前数据库 也就是person这个数据库
4.删除数据库
db.dropDatabase()
5.断开连接
exit
6.查看命令api
help
操作集合
操作集合方法
查看帮助api
语法
db.worker.help()
查看当前数据库下有哪集合(collection)
语法
show collections
创建集合(collection)
1. 使用 db.createCollection(collection_Name)方法
语法
db.createCollection(“collection_Name”) collection_Name集合的名称
2. 使用 db.collection_Name.insert(document)方法
语法
db.collection_Name.insert(document) collection_Name集合的名称 document要插入的文档
注:两者的区别在于前者创建了一个空的worker集合 后者创建了一个空的worker集合并添加了一个Document数据
删除当前数据库中的集合(collection)
语法
db.collection_Name.drop() collection_Name 集合的名称
文档操作
插入文档
1、 使用insert()方法插入文档
语法
db.collection_name.insert(document) collection_name集合的名字 document插入的文档
实例
db.worker.insert({name:’zpx’,age:6}) 向worker集合添加一个{name:’zpx’,age:6}的Document
db.worker.insert([{name:’wangWu’,age:50},{name:’xiaoMing’,age:60}]) 向worker集合添加多个[{name:’wangWu’,age:50},{name:’xiaoMing’,age:60}] 的Document
2、 使用save()方法插入文档
语法
db.collection_name.save(document) collection_name集合的名字 document插入的文档
注:如果不指定 _id 字段 save() 方法类似于 insert() 方法。如果指定 _id 字段,则会更新该 _id 的数据。
实例
db.person.save({name:”xiaoHong”,age:50})
db.person.save({_id:ObjectId(“562c9caf671c978b6596e825”),name:”xiaoHong”,age:10})