在Mac OS上安装使用MongoDB的教程

 更新时间:2016年02月14日 16:38:15   作者:trigkit4  
这篇文章主要介绍了在Mac OS上安装使用MongoDB的教程,包括MongoDB基本的命令与数据类型的讲解,如果在开发环境中调试的话相当推荐阅读本文,需要的朋友可以参考下

概念
MongoDB 是一个跨平台的,面向文档的数据库,提供高性能,高可用性和可扩展性方便。 MongoDB 工作在收集和文件的概念。

什么是NoSql?
NoSql,全称是 Not Only Sql,指的是非关系型的数据库。下一代数据库主要解决几个要点:非关系型的、分布式的、开源的、水平可扩展的。原始的目的是为了大规模web应用,这场运动开始于2009年初,通常特性应用如:模式自由、支持简易复制、简单的API、最终的一致性(非ACID)、大容量数据等。NoSQL被我们用得最多的当数key-value存储,当然还有其他的文档型的、列存储、图型数据库、xml数据库等。

为什么要使用MongoDB
JSON风格文件的形式,面向文档存储:数据存储

  • 对任何属性可索引
  • 复制和高可用性
  • 自动分片
  • 丰富的查询
  • 快速就地更新

MongoDB的专业技术支持
应该在哪里使用MongoDB?

  • 大数据
  • 内容管理和交付
  • 移动和社交基础设施
  • 用户数据管理
  • 数据平台

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。

基本的用法是存储JSON数据,这很适合JavaScript程序。其特性如下:

   1. 没有表结构的概念,每条记录可以有完全不同的结构
   2. 业务开发方便快捷
   3. sql数据库需要事先定义表结构再使用
在Mac下安装MongoDB
第一种、用浏览器或者第三方工具下载
当前版本的下载地址: http://downloads.mongodb.org/osx/mongodb-osx-x86_64-2.4.6.tgz

或者第二种、打开终端,使用以下命令行下载:

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数据库的信息,则表示启动成功。

成功后的界面:

2016214163431121.jpg (600×306)

安装步骤
1.首先在终端输入ls,列出目录,找到你的mongodb文件,以tgz结尾的

2016214163451389.jpg (567×366)

2.打开终端,输入tar -zxvf mongodb-osx-x86_64-2.4.6,当然各自的版本号自己对应正确了啊。

3.将解压的安装文件移动到你所喜欢的位置:

mv -n ~/Downloads/mongodb-osx-x86_64-2.4.6 ~/Applications/mongodb/

我的解压目录是Downloads,默认移到Applications的mongodb文件夹是看不见的

4、在根目录 / 下创建  data/db 目录,用于放置mongodb数据,并且给该目录设置权限

sudo mkdir -p /data/db
sudo chown -R trigkit4 /data

5.启动mongodb 服务

打开终端,输入cd Applications/mongodb/bin,回车后,再输入./mongod

2016214163543813.jpg (585×366)

6.打开另外一个终端,输入Applications/mongodb/bin,回车,输入 ./mongo

2016214163559981.jpg (464×366)

文档
文档是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中的基本操作
在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 命令
MongoDB use DATABASE_NAME 用于创建数据库。该命令将创建一个新的数据库,如果它不存在,否则将返回现有的数据库。

dropDatabase() 方法
MongoDB db.dropDatabase() 命令是用来删除一个现有的数据库。
dropDatabase() 命令的基本语法如下:

db.dropDatabase()
drop() 方法
MongoDB 的 db.collection.drop() 是用来从数据库中删除一个集合。

insert() 方法
要插入数据到 MongoDB 集合,需要使用 MongoDB 的  insert() 或 save() 方法。

find() 方法
要从MongoDB 查询集合数据,需要使用MongoDB 的 find() 方法。

pretty() 方法
结果显示在一个格式化的方式,可以使用 pretty() 方法.

Limit() 方法
要限制 MongoDB 中的记录,需要使用 limit() 方法。 limit() 方法接受一个数字型的参数,这是要显示的文档数。
语法:

limit() 方法的基本语法如下

>db.COLLECTION_NAME.find().limit(NUMBER) 

MongoDB 数据转储
创建备份MongoDB中的数据库,应该使用mongodump命令。
mongodump命令的基本语法如下:

>mongodump

恢复数据
恢复备份数据使用MongoDB 的 mongorerstore 命令。此命令将恢复所有的数据从备份目录。
语法:

mongorestore命令的基本语法

>mongorestore

剩下的方法或命令大家都可以去网上搜索的,这里就不接着赘述了啊。

相关文章

  • MongoDB分片测试

    MongoDB分片测试

    分片是mongoDB扩展的一种方式。分片分割一个collection并将不同的部分存储在不同的机器上,本文给大家介绍MongoDB分片测试,需要的朋友参考下吧
    2016-03-03
  • mongodb 查看数据库和表大小

    mongodb 查看数据库和表大小

    mongodb查看数据库和表的方法比较简单,在为这里推荐使用stats的方法,直观并且详细。
    2014-07-07
  • 关于对MongoDB索引的一些简单理解

    关于对MongoDB索引的一些简单理解

    索引的作用是为了提升查询效率,如果查询条件带有索引,MongoDB 将扫描索引, 通过索引确定要查询的部分文档,而非直接对全部文档进行扫描,下面这篇文章主要给大家介绍了关于对MongoDB索引的一些简单理解,需要的朋友可以参考下
    2021-09-09
  • Linux服务器下MariaDB 10自动化安装部署

    Linux服务器下MariaDB 10自动化安装部署

    这篇文章主要介绍了Linux服务器下MariaDB 10自动化安装部署,需要的朋友可以参考下
    2016-08-08
  • 如何为MongoDB添加分片副本集

    如何为MongoDB添加分片副本集

    这篇文章主要介绍了如何为MongoDB添加分片副本集,帮助大家更好的理解和学习使用MongoDB数据库,感兴趣的朋友可以了解下
    2021-03-03
  • MongoDB数据库两阶段提交实现事务的方法详解

    MongoDB数据库两阶段提交实现事务的方法详解

    这篇文章主要介绍了MongoDB数据库两阶段提交实现事务的方法,结合实例形式详细分析了MongoDB数据库事务提交、回滚、撤销等操作的原理、实现方法及相关操作注意事项,需要的朋友可以参考下
    2018-08-08
  • MongoDB数据库去重函数Distinct用法实例

    MongoDB数据库去重函数Distinct用法实例

    在MongoDB中可以使用distinct()方法对变量进行去重操作,distinct()方法是用于返回指定字段的唯一值的操作,这篇文章主要给大家介绍了关于MongoDB数据库去重函数Distinct用法的相关资料,需要的朋友可以参考下
    2024-06-06
  • 使用mongoose和bcrypt实现用户密码加密的示例

    使用mongoose和bcrypt实现用户密码加密的示例

    下面小编就为大家分享一篇使用mongoose和bcrypt实现用户密码加密的示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • MongoDB操作类封装实例代码

    MongoDB操作类封装实例代码

    这篇文章主要给大家介绍了关于MongoDB操作类封装的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • MongoDB的安装及配置文件选项全解

    MongoDB的安装及配置文件选项全解

    本文收录了MongoDB的安装及配置文件选项全解,介绍了MongoDB安装的方法以及环境下的一些重要文件,还有最重要的是详细地罗列了配置文件中的选项含义和参数,需要的朋友可以参考下
    2016-07-07

最新评论