MongoDB
是一个跨平台的,面向文档的数据库,提供高性能,高可用性和可扩展性方便。 MongoDB
工做在收集和文件的概念。javascript
NoSql
,全称是 Not Only Sql
,指的是非关系型的数据库。下一代数据库主要解决几个要点:非关系型的、分布式的、开源的、水平可扩展的。原始的目的是为了大规模web
应用,这场运动开始于2009年初,一般特性应用如:模式自由、支持简易复制、简单的API
、最终的一致性(非ACID
)、大容量数据等。NoSQL
被咱们用得最多的当数key-value
存储,固然还有其余的文档型的、列存储、图型数据库、xml
数据库等。css
JSON风格文件的形式,面向文档存储:数据存储 对任何属性可索引 复制和高可用性 自动分片 丰富的查询 快速就地更新 MongoDB的专业技术支持
大数据 内容管理和交付 移动和社交基础设施 用户数据管理 数据平台
MongoDB
是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构很是松散,是相似json
的bson
格式,所以能够存储比较复杂的数据类型。java
基本的用法是存储JSON
数据,这很适合JavaScript
程序。其特性以下:web
1. 没有表结构的概念,每条记录能够有彻底不一样的结构 2. 业务开发方便快捷 3. sql数据库须要事先定义表结构再使用
第一种、用浏览器或者第三方工具下载
当前版本的下载地址: http://downloads.mongodb.org/osx/mongodb-osx-x86_64-2.4.6.tgz
正则表达式
或者第二种、打开终端,使用如下命令行下载:sql
curl http://downloads.mongodb.org/osx/mongodb-osx-x86_64-2.4.6.tgz > mongodb.tgz
安装成功以后,“mongod”
命令启动mongo
数据库。浏览器下输入http://127.0.0.1:28017 若是能正常显示mongo
数据库的信息,则表示启动成功。mongodb
成功后的界面:shell
1.首先在终端输入ls
,列出目录,找到你的mongodb
文件,以tgz
结尾的数据库
2.打开终端,输入tar -zxvf mongodb-osx-x86_64-2.4.6
,固然各自的版本号本身对应正确了啊。express
3.将解压的安装文件移动到你所喜欢的位置:
mv -n ~/Downloads/mongodb-osx-x86_64-2.4.6 ~/Applications/mongodb/
个人解压目录是Downloads
,默认移到Applications
的mongodb
文件夹是看不见的
四、在根目录 / 下建立 data/db
目录,用于放置mongodb
数据,而且给该目录设置权限
sudo mkdir -p /data/db sudo chown -R trigkit4 /data
5.启动mongodb
服务
打开终端,输入cd Applications/mongodb/bin
,回车后,再输入./mongod
6.打开另一个终端,输入Applications/mongodb/bin
,回车,输入 ./mongo
文档是MongoDB
的核心概念,多个键及其关联的值有序地放置在一块儿即是文档。 在js
里,文档表示为对象:
{"greenting" : "Hello,world!"}
这个对象只有一个键"greeting
",其对应的值"Hello,world!
"
文档的键是字符串,除少数例外状况,键可使用任意UTF-8
字符:
- 键不能含有\0(空字符)。这个字符用来表示键的结尾 - .和$有特别的意义,只有当特定环境下才能使用,一般来讲是被保留了 - 如下划线"_"开头的键是保留的,虽然不是严格要求的
MongoDB
不单区分类型,也区分大小写,还有,MongoDB
的文档不能有重复的键,例以下面的文档是非法的:
{"greeting":"Hello,world!","greeting":"Hello,mongoDB!"}
集合是一组文档。若是说MongoDB
中的文档相似于关系型数据库中的行,那么集合就如同表。
集合是无模式的。这意味着集合里面的文档能够是各式各样的,例以下面两个文档能够存在于同一个集合里面:
{"greeting": "Hello,world!"} {"foo": 5}
咱们能够经过名字来标示集合。集合名能够是知足下列条件的UTF-8
条件
- 集合名不能是空字符串""。 - 集合名不能含有\0字符(空字符) - 集合名不能以"system."开头,这是为系统集合保留的前缀 - 用户建立的集合名字不能含有保留字符$
组织集合的一种惯例是使用"."
字符分开的按命名空间划分的子集合。
在shell
查看数据会用到4个基本操做:建立、读取、更新和删除(CRUD
)
MongoDB
中多个文档组成集合,一样多个集合能够组成数据库。一个MongoDB
实例能够承载多个数据库,数据库名能够是知足如下条件的任意UTF-8
字符串
- 不能是空字符串("") - 不能含有''(空格)、.、$、/、\和\0(空字符) - 应所有小写 - 最多64字节
MongoDB
支持许多数据类型的列表下面给出:
String : 这是最经常使用的数据类型来存储数据。在MongoDB中的字符串必须是有效的UTF-8。 Integer : 这种类型是用来存储一个数值。整数能够是32位或64位,这取决于您的服务器。 Boolean : 此类型用于存储一个布尔值 (true/ false) 。 Double : 这种类型是用来存储浮点值。 Min/ Max keys : 这种类型被用来对BSON元素的最低和最高值比较。 Arrays : 使用此类型的数组或列表或多个值存储到一个键。 Timestamp : 时间戳。这能够方便记录时的文件已被修改或添加。 Object : 此数据类型用于嵌入式的文件。 Null : 这种类型是用来存储一个Null值。 Symbol : 此数据类型用于字符串相同,但它一般是保留给特定符号类型的语言使用。 Date : 此数据类型用于存储当前日期或时间的UNIX时间格式。能够指定本身的日期和时间,日期和年,月,日到建立对象。 Object ID : 此数据类型用于存储文档的ID。 Binary data : 此数据类型用于存储二进制数据。 Code : 此数据类型用于存储到文档中的JavaScript代码。 Regular expression : 此数据类型用于存储正则表达式
MongoDB use DATABASE_NAME
用于建立数据库。该命令将建立一个新的数据库,若是它不存在,不然将返回现有的数据库。
MongoDB db.dropDatabase()
命令是用来删除一个现有的数据库。dropDatabase()
命令的基本语法以下:
db.dropDatabase()
MongoDB
的 db.collection.drop()
是用来从数据库中删除一个集合。
要插入数据到 MongoDB
集合,须要使用 MongoDB
的 insert()
或 save()
方法。
要从MongoDB
查询集合数据,须要使用MongoDB
的 find()
方法。
结果显示在一个格式化的方式,可使用 pretty()
方法.
要限制 MongoDB
中的记录,须要使用 limit()
方法。 limit()
方法接受一个数字型的参数,这是要显示的文档数。
语法:
limit()
方法的基本语法以下
>db.COLLECTION_NAME.find().limit(NUMBER)
建立备份MongoDB
中的数据库,应该使用mongodump
命令。mongodump
命令的基本语法以下:
>mongodump
恢复备份数据使用MongoDB
的 mongorerstore
命令。此命令将恢复全部的数据从备份目录。
语法:
mongorestore
命令的基本语法
>mongorestore
剩下的方法或命令你们均可以去网上搜索的,这里就不接着赘述了啊。