文档章节

野心勃勃的NoSQL新贵 MongoDB应用实战(1)

浮躁的码农
 浮躁的码农
发布于 2016/04/13 08:35
字数 2196
阅读 17
收藏 0
点赞 1
评论 0

MongoDB是一个基于分布式文件存储的数据库,由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。其名字来自humongous这个单词的中间部分,从名字可见其野心所在就是海量数据的处理。本文是一个MongoDB的入门级教程,手把手的教会读者使用MongoDB,并将学习过程中可能遇到的问题一一列举。本文不是用长篇的文字来理论性描述MongoDB的各方面知识,而是用图文并茂的方法来讨论MongoDB,希望用最短的时间使开发人员熟悉MongoDB。

一、MongoDB简介

2011年将被记住,因为这一年SQL将死;这一年,关系数据库从一线退下;这一年开发人员发现他们没必要为了持久化数据,而将每个对象转化为表格结构。

2011年是文档数据库的一年,尽管一直在稳步发展势头,通过过去八年多的发展,现在有各种稳定的文档数据库——从基于亚马逊和谷歌的云,到各种开放源码工具,尤其是MongoDB。

那么,MongoDB是什么?这里的五件事是每个开发人员应该知道的:

1、MongoDB 是一个独立的服务器

如MySQL或PostgreSQL一样,MongoDB提供侦听端口以便接入。它提供了用于查询,创建,更新和删除的工具。从理论上讲,你使用它的工作方式与你使用MySQL或PostgreSQL的工作方式相同:连接,执行任务,并关闭连接。

2、MongoDB是非结构化的

MongoDB 没有结构化语言。如果你想创建一个新的文档类型,你不用做任何事来告诉数据库关于这些数据的结构,而仅仅是存到数据库中即可。

简单的说,MongoDB使用类似JavaScript或PHP的类型处理方式。也就是说,数据库是灵活的弱类型。

虽然有一些数据是有限制条件的(大块的数据可能需要一些明确的处理),,但在大多数情况下,你可以像写PHP代码一样编写你的MongoDB代码。

3、不必去学习另一种查询语言

还记得这些你写的数据库抽象层吗?还记得那些你处理过的ORM层吗?现在,你可以将它们全部丢弃。在MongoDB中你不需要他们。MongoDB没有很多查询语句。在大多数情况下,只需给它一个数组指定你想要的信息,然后它会给你返回文档的数组。如果你想运行一些非常复杂的查询(如Map-Reduce操作),可以向MongoDB传递JavaScript,其内部的JavaScript引擎可以解析这个脚本。

4、MongoDB是神速的

开发时间也短,因为没有结构需要管理和很少(如果有的话)的数据映射。

学习曲线很平滑,因为没有新的查询语言学习。代码是简洁的。毕竟,无须任何其他ORM,封装可以非常简单。你的代码是未来的保证。向你的对象增加更多的字段是很轻松的。因此,需求变化了,你可以很快修改代码以便适应。

MongoDB足以让我意识到它有改变游戏规则的潜力。这也是让大家主张使用新一代的文档数据库代替基于SQL的关系数据库的原因。将关系数据库留在尘土里,更可能的是让它们做它们能做好的事情:存储属于行和表的数据。

二、MongoDB服务器安装

MongoDB的官方下载站是,可以去上面下载最新的程序下来。在下载页面可以看到,对操作系统支持很全面,OS X、Linux、Windows、Solaris都支持,而且都有各自的32位和64位版本。目前的稳定版本是1.8.1版本。

野心勃勃的NoSQL新贵 MongoDB应用实战(1)

注意:

1. MongoDB 1.8.1 Linux版要求glibc必须是2.5以上,所以需要先确认操作系统的glibc的版本,笔者最初用Linux AS 4安装不上,最后用的是RHEL5来安装才成功的;

2. 在32位平台MongoDB不允许数据库文件(累计总和)超过2G,而64位平台没有这个限制。本文都是采用32位系统。

Windows版本服务器安装

(1)、下载MongoDB

url地址:

(2)、设置MongoDB目录

将其解压到 d:\,再重命名为mongodb,路径为d:\mongodb

(3)、设置数据文件路径

在d:盘建一个db文件夹,路径d:\db

(4)、启动MongoDB服务

进入 cmd 提示符控制台,D:\mongodb\bin\mongod.exe --dbpath=d:\data\db

MongoDB服务端的默认连接端口是 27017

(5)、将MongoDB作为 Windows 服务随机启动

先创建D:\mongodb\logs\mongodb.log文件,用于存储MongoDB的日志文件, 再安装系统服务:

(6)、客户端连接验证

新打开一个CMD输入:d:\mongodb\bin\mongo,如果出现下面提示,那么您就可以开始MongoDB之旅了:

(7)、查看MongoDB日志

查看D:\mongodb\logs\mongodb.log文件,即可对MongoDB的运行情况进行查看或排错了:

野心勃勃的NoSQL新贵 MongoDB应用实战(1)

 

这样就完成了Windows平台的MongoDB安装。

Linux版服务器安装

(1)、下载MongoDB

curl -O

(2)、设置MongoDB目录

将其解压到/Apps,再重命名为mongodb,路径为/Apps/mongodb

(3)、设置数据文件路径

建立/data/db的目录, mkdir –p /data/db

(4)、启动MongoDB服务

MongoDB 服务端的默认连接端口是 27017

(5)、将MongoDB作为 Linux 服务随机启动

先创建/Apps/mongodb/logs/mongodb.log文件,用于存储MongoDB的日志文件

vi /etc/rc.local, 使用vi编辑器打开配置文件,并在其中加入下面一行代码

  • (6)、客户端连接验证

    新打开一个Session输入:/Apps/mongodb/bin/mongo,如果出现下面提示,那么您就可以开始mongo之旅了

    (7)、查看MongoDB日志

    查看/Apps/mongodb/logs/mongodb.log文件,即可对MongoDB的运行情况进行查看或排错了

    这样就完成了Linux平台的MongoDB安装。

    三、MongoDB客户端访问 – Shell方式

    MongoDB是MongoDB自带的交互式Javascript shell,用来对MongoDB进行操作和管理的交互式环境。

    使用 "./mongo --help" 可查看相关连接参数,下面将从常见的操作,如插入,查询,修改,删除等几个方面阐述MongoDB shell的用法

    1、插入记录

    本例向数据库my_mongodb的表user中插入了2条记录。MongoDB会隐式的创建数据库my_mongodb和表user,所以这个例子没有建库和建表的过程,可以通过show dbs和show collections来查看数据库及表,具体如下:

    2、查询记录

    查询表中的全部记录:

    查询用户名是 ”Jerry” 记录:

    3、修改记录

    将用户ID是2的记录的年龄修改为100:

    查询一下是否改过来了:

    4、删除记录

    将用户ID是1的记录从表user中删除:

    经验证,该记录确实被删除了。

    MongoDB Shell的用法丰富且简单易懂,大家有兴趣可以到官网上去详细了解一下。

    四、MongoDB客户端访问 – C#

    接下来我们要开始最简单的MongoDB连接,访问数据之旅了。MongoDB提供各种主流与非主流语言的开发驱动,以便适应各个方向的开发人员。

    1、下载驱动

    C#驱动的下载地址为:

    https://github.com/downloads/mongodb/mongo-csharp-driver/CSharpDriver-1.0.0.4098.zip

    将其解压到D:\mongodb\drivers\目录下,其中有2个重要的dll文件

    MongoDB.Bson.dll --序列化、Json相关

    MongoDB.Driver.dll --驱动

    2、添加引用

    新建一个C#的项目,添加引用,将上面两个dll文件引入到项目里面:

    野心勃勃的NoSQL新贵 MongoDB应用实战(1)

     

    3、代码解析

    下面以一个插入的操作为例,来一步一步解释代码:



     using System;
    
      using System.Collections.Generic;
    
      using System.Linq;
    
      using System.Text;
    //添加命名空间
      using MongoDB.Bson;
    
      using MongoDB.Driver;
    
      namespace ConsoleApplication3
    
      {
      class Program
    
      {
    
    static void Main(string[] args)
    
      {
    //MongoDB服务器连接串
    
      string connectionString = mongodb://192.168.1.103;
    
    
    
      MongoServer server = MongoServer.Create(connectionString);
    
    
    //连接到 mongodb_c_demo 数据库
      MongoDatabase db = server.GetDatabase(mongodb_c_demo);
    
      //获取集合 fruit
    
      MongoCollection collection = db.GetCollection(fruit);
    
      //创建对象 fruit_1
    
      BsonDocument fruit_1 = new BsonDocument
    
      {
      { name, apple },
    
      { color, red }
    
    
    
      };
    
      //创建对象 fruit_2
    
      BsonDocument fruit_2 = new BsonDocument
    
    
    
      {
    
      { name, banana },
    
    
    
      { color, yellow }
    
      };
    
    
    //将对象 fruit_1 放到集合 fruit 中
    
    
      collection.Insert(fruit_1);
    
    
    //将对象 fruit_2 放到集合 fruit 中
    
    
      collection.Insert(fruit_2);
    
    
    //以上代码完成的就是向fruit表中插入2条数据,用mysql的语法解释即
    
      //insert into mongodb_c_demo.fruit (name, color)
    
      //values (apple, red), (banana, yellow);
    
    
      }
    
      }
    
    }

      4、通过MongoDB Shell来验证是否插入:


    > use mongodb_c_demo
      switched to db mongodb_c_demo
    
      > db.fruit.find();
    
      { _id : ObjectId(4da1c5fdfad96211a08f5752), name : apple, color : red }
    
      { _id : ObjectId(4da1c5fdfad96211a08f5753), name : banana, color : yellow }





    © 著作权归作者所有

    共有 人打赏支持
    浮躁的码农

    浮躁的码农

    粉丝 58
    博文 717
    码字总数 142223
    作品 0
    松江
    程序员
    将mongodb安装为windows服务

    首先 下载mongodb: http://www.mongodb.org/downloads 解压到自己喜欢的一个目录 D:nosqlmongodb 配置MONGODB_HOME环境变量 MONGODB_HOME=D:nosqlmongodbmongodb-win32-i386-2.0.6 修改pat......

    varlardoha
    2013/01/15
    0
    1
    MongoDB学习心得(整理中)

    NoSQL(Not Only SQL)-非关系型数据库,又一种流行的数据库技术。除去复杂、臃肿的结构化语言,简单的几个函数就可以完成增删该处基本操作。NoSQL好比一个灵活的猴子,而SQL就像大笨象了。 ...

    cjp路人
    2013/11/03
    0
    0
    NoSQL性能测试:MongoDB VS SequoiaDB

    作为NoSQL的一个重要类型,文档型NoSQL通常被认为是最接近传统关系型数据库的NoSQL。文档型NoSQL的核心是数据嵌套,这种设计可以从某 种程度上大大简化传统数据库复杂的关联问题。同时由于摆...

    SequoiaDB2013
    2013/09/15
    0
    0
    搭建高可用mongodb集群(一)——配置mongodb

    在大数据的时代,传统的关系型数据库要能更高的服务必须要解决高并发读写、海量数据高效存储、高可扩展性和高可用性这些难题。不过就是因为这些问题Nosql诞生了。 NOSQL有这些优势: 大数据量...

    观澜而索源
    2013/11/18
    0
    0
    #搭建高可用mongodb集群(一)——配置mongodb

    本博客已迁移至 [www.0x520.com][1] [1]:http://www.0x520.com 搭建高可用mongodb集群(一)——配置mongodb 在大数据的时代,传统的关系型数据库要能更高的服务必须要解决高并发读写、海量数...

    小小霸王枪
    2013/12/26
    0
    5
    MongoDB、Cassandra 和 HBase 三种 NoSQL 数据库比较

    本文由伯乐在线 -徐汉彬 翻译。未经许可,禁止转载! 英文出处: infoworld。欢迎加入 翻译组。 Hadoop获得了许多大数据应用的信誉,但实际情况是,NoSQL数据库是一直处于更加广泛部署和更广...

    伯乐在线
    2015/09/24
    0
    0
    [翻译]MongoDb 架构(MongoDb Architecture)

    转自:http://blog.dufei.cc/index.php/archives/25/ NOSQL最近成为了一个炙手可热的话题(作者发表在2012年,话说对于现在来说,NOSQL已经如火如荼了)。大规模架构的web服务开发中对于高扩...

    少说绝对
    2015/04/02
    0
    0
    mongodb集群故障转移实践

    简介 NOSQL有这些优势: 大数据量,可以通过廉价服务器存储大量的数据,轻松摆脱传统mysql单表存储量级限制。 高扩展性,Nosql去掉了关系数据库的关系型特性,很容易横向扩展,摆脱了以往老是...

    全部原谅
    07/17
    0
    0
    Node.js和Geddy初学者指南 - 第三部分:使用Mongdb持久化你的数据

    日期:2012-4-12 来源:GBin1.com 在这个三个部分的教程中,我们教大家使用Node.js和Geddy来创建了一个todo的管理应用,上一篇我们将数据保存在内存中,在这个系列最后一篇文章中,我们将介绍...

    gbin1
    2012/04/13
    0
    0
    存储大量爬虫数据的数据库,了解一下?

    "当然, 并不是所有数据都适合" 在学习爬虫的过程中, 遇到过不少坑. 今天这个坑可能以后你也会遇到, 随着爬取数据量的增加, 以及爬取的网站数据字段的变化, 以往在爬虫入门时使用的方法局限性...

    fesoncn
    04/09
    0
    0

    没有更多内容

    加载失败,请刷新页面

    加载更多

    下一页

    expect脚本同步文件、expect脚本指定host和要同步的文件、构建文件分发系统

    expect脚本同步文件 更改权限 执行脚本 查看执行结果 expect eof需要加上,作用是等脚本命令执行完再进行退出 expect脚本指定host和要同步的文件 更改权限,执行脚本 构建文件分发系统 需求背...

    Zhouliang6
    34分钟前
    1
    0
    Hive应用:外部分区表

    Hive应用:外部分区表 介绍 Hive可以创建外部分区表。创建表的时候,分区要在建表语句中体现。建完之后,你不会在表中看到数据,需要进行分区添加,使用alter语句进行添加。然后数据才会显示...

    星汉
    45分钟前
    2
    0
    点击Enter登录

    1. 效果 2. 实现过程(记得引入jq文件) //6.回车事件 登录 $(function() { document.onkeydown = function(event) { var e = event || window.event || arguments.callee.caller.arguments......

    Lucky_Me
    50分钟前
    1
    0
    点击菜单内容切换

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .menu{ height: 38px; background-color: #eeeeee; line-height: 38px; } .mao{ ......

    南桥北木
    今天
    1
    0
    OSChina 周六乱弹 —— 妹子和游戏哪个更好玩

    Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @andonny :分享唐朝乐队的单曲《国际歌》 《国际歌》- 唐朝乐队 手机党少年们想听歌,请使劲儿戳(这里) @举个栗子- :日常祈雨 邪恶的大祭...

    小小编辑
    今天
    548
    6
    流利阅读笔记32-20180721待学习

    “人工智能”造假:只有人工,没有智能 Lala 2018-07-21 1.今日导读 当今社会,擅长单个方面的人工智能已经盛行,手机借助 AI 智慧防抖技术帮助大家拍出清晰照片,谷歌研发的 AI 助手将可以帮...

    aibinxiao
    今天
    8
    0
    我的成长记录(一)

    今天突然精神抖擞,在我的博客下新开一项分类>成长记录,专门记录每隔一段时间我的一点感悟吧。因为今天才专门花时间新开这样一个分类,所以以前有过的一些感悟没有记录下来,现在已经想不起...

    dtqq
    今天
    1
    0
    机器学习管理平台 MLFlow

    最近工作很忙,博客一直都没有更新。抽时间给大家介绍一下Databrick开源的机器学习管理平台-MLFlow。 谈起Databrick,相信即使是不熟悉机器学习和大数据的工程湿们也都有所了解,它由Spark的...

    naughty
    今天
    16
    0
    idea tomcat 远程调试

    tomcat 配置 编辑文件${tomcat_home}/bin/catalina.sh,在文件开头添加如下代码。    CATALINA_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=7829" Idea端配......

    qwfys
    今天
    2
    0
    遍历目录下的文件每250M打包一个文件

    #!/usr/bin/env python # -*- utf-8 -*- # @Time : 2018/7/20 0020 下午 10:16 # @Author : 陈元 # @Email : abcmeabc@163.com # @file : tarFile.py import os import tarfile import thr......

    寻爱的小草
    今天
    1
    0

    没有更多内容

    加载失败,请刷新页面

    加载更多

    下一页

    返回顶部
    顶部