当前位置: 首页 > news >正文

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

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

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 }





转载于:https://my.oschina.net/weiweiblog/blog/657768

相关文章:

  • Palo Alto Networks的下一代安全方法论
  • 经典算法题每日演练——第二题 五家共井
  • 利用接口给任意对象进行排序
  • 我们也说说Android.mk(5) - 计算怎么办?
  • 一些小脚本与正则表达式
  • 【案例】常驻查询引发的thread pool 性能问题之一
  • ASP.NET Core的身份认证框架IdentityServer4(6)- 开始
  • maven - pom.xml 聚合(父)工程 基本内容演示
  • service
  • 波特率时钟
  • HBase的一些关于CRUD方法
  • 自动化测试基础篇--Selenium单选框(Radio)复选框(CheckBox)
  • 基于图论的立体匹配方法研究----绪论
  • rails migration 增加索引
  • len(),range()函数
  • Android组件 - 收藏集 - 掘金
  • es6
  • Java应用性能调优
  • SpringCloud集成分布式事务LCN (一)
  • springMvc学习笔记(2)
  • 第2章 网络文档
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 构造函数(constructor)与原型链(prototype)关系
  • 开发了一款写作软件(OSX,Windows),附带Electron开发指南
  • 理解在java “”i=i++;”所发生的事情
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 删除表内多余的重复数据
  • AI又要和人类“对打”,Deepmind宣布《星战Ⅱ》即将开始 ...
  • zabbix3.2监控linux磁盘IO
  • 大数据全解:定义、价值及挑战
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • 容器镜像
  • ​软考-高级-系统架构设计师教程(清华第2版)【第9章 软件可靠性基础知识(P320~344)-思维导图】​
  • # Java NIO(一)FileChannel
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • #中的引用型是什么意识_Java中四种引用有什么区别以及应用场景
  • (九)c52学习之旅-定时器
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (转)mysql使用Navicat 导出和导入数据库
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • .h头文件 .lib动态链接库文件 .dll 动态链接库
  • .libPaths()设置包加载目录
  • .Net 知识杂记
  • .Net中间语言BeforeFieldInit
  • /etc/shadow字段详解
  • /usr/bin/env: node: No such file or directory
  • [2021 蓝帽杯] One Pointer PHP
  • [AIGC 大数据基础]hive浅谈
  • [BZOJ3223]文艺平衡树
  • [C语言]——柔性数组
  • [Excel VBA]单元格区域引用方式的小结
  • [HNOI2008]水平可见直线
  • [leetcode] 3Sum
  • [LeetCode] Copy List with Random Pointer 拷贝带有随机指针的链表
  • [PHP]禅道项目管理软件ZenTaoPMS源码包 v16.4